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REAL-TIME AUTOMATED TRADING SYSTEM 

5 

Field of Invention 

The present invention is directed to an 
automated trading system that operates in real-time, and 
more particularly, to an integrated trading and order 
10 management system for use by investors. 

Copyright Notice 

A portion of the disclosure of this patent 
document contains material which is subject to copyright 
15 protection. The copyright owner has no objection to the 
facsimile reproduction by anyone of the patent document 
or patent disclosure as it appears in the Patent and 
^Trademark Office, .patent file or records, but otherwise 
- Reserves all copyright rights whatsoever. 

20 

Background of the Invention 

Current methods for buying and selling - 
securities are inefficient and involve needless human 
intervention. Computer systems have been developed to 
25 assist brokers in trading securities and also to improve 
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the efficiency of particular stock exchanges. However, 
even when using these computer systems to trade 
securities, there is still a high degree of human 
interaction. 

5 The securities market has a complex -structure. 

There are numerous stock exchanges, and electronic trading 
systems available to an investor and located in various 
• places throughout the world. A corporation may have its 
shares listed on one or more exchanges. The price quoted 

10 by each exchange for a particular security may vary from 
exchange to exchange. Each exchange has its own trading 
rules. The way. a trade is executed on each exchange may 
be different. The computer systems that have been * 
developed to assist in the placing and execution of 

15 orders are usually limited to one exchange and differ- 
between the exchanges. The systems for communication of 
execution information to the investors greatly vary. To 
add complication, there are many thousands of different 
securities traded each day. 

20 An investor who wishes to trade securities on 

each exchange is thus confronted with numerous and 
diverse trading systems. Even if the investor limited 
trading to just one exchange, the investor will find that 
he or she has little direct control over the execution of 
- 25 the investor's orders, and is often not provided with 
execution information in real-time. 

The following is an example of the typical 
steps that take place when an investor, such as an 
institutional investor, wishes to trade a security. A 

30 portfolio manager at the institution periodically 

examines a quote device which is located\on the portfolio 
manager's desk. Typically, the quote device lists the 
prices and quantities at which securities can be traded 
on a particular stock exchange. The portfolio manager 

35 most likely concentrates on the price of a small number 
of stocks. The portfolio manager, manually or with the 
aid of a computerized model, then makes a decision to buy 
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or sell a particular stock based on the current price of 
that stock shown on the quote device. When the decision 
is made, the portfolio manager will most likely telephone 
a professional trader at the institution's trading desk 
5 with the order. 

The professional trader/ who usually is 
employed by the institution, may be given little 
information about why the decision to buy or sell the 
stock was made. The professional trader may not have 

10 dealt in that particular stock for quite some time, so 
must then determine which securities firm to contact to 
place the order. There are many securities firms, each 
often specializing in certain stocks. The professional 
trader will usually telephone a block trader (or 

15 salesman) at a selected securities firm. The securities 
firm's trader (or salesman) takes the order and routes it 
to the correct department or desk of the securities firm. 
The trader (or salesman) may do this by physically taking 
a piece of paper with the order written on it to the 

20 correct department or desk, or telephone (or yell) the 
order to a person in the department or at the desk. 
Another trader who deals in that stock then determines, 
based on factors such as the size of the order, how best 
to execute the order. 

25 Usually, the trader will first determine the 

likelihood that the firm can itself find a counterpart to 
the order, for example, by telephoning some of the 
securities firm's other clients or by matching the order 
with other orders that the securities firm has on its 

30 books. If this cannot easily be done, the trader will 
then send the order to an exchange. . 

The trader has the choice of different 
exchanges and of different mechanisms to obtain execution 
of the order at an exchange. For example, the trader may 

35 have the choice of executing the order on the New York 
Stock Exchange (NYSE) , the NYSE DOT system, the Pacific 
Stock Exchange or on Instinet. 
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As an example, assume the trader decides to 
place the order on the New York Stock Exchange (NYSE) 
assuming, of course, that the stock is listed on that 
exchange. The trader could do this, for example, by 
5 telephoning the securities firm's floor broker, located 
in a booth on the floor of the exchange. Alternatively, 
the trader could send the order by computer or wire to 
the securities firm's booth on the floor of the exchange, 
where the order is then printed on a printer. A floor 

10 ; broker will then take the order to. the appropriate 

specialist post to execute the trade. Each company's 
stock trades at only one post on the floor of the 
exchange so that trading can be tracked and kept orderly. 
{At most posts, however, several companies' stock trade 

15 at one time, depending on how much combined trading 

activity they generate.) The specialist is a broker's 
broker. The specialist keeps a book of orders in a 
particular security. The floor broker will physically 
speak to the specialist to execute the trade. . After 

20 every deal, a reporter places a mark sense card into a 
reporting device, and the transaction appears on the 
ticker almost instantly. Confirmation back to the 
investor or customer takes place when the floor broker 
returns to the firm's booth and sends the trade details 

25 over the wire (or by telephone or by computer) to the 
broker's branch, confirming' that the order has been 
carried out successfully. 

Back at the broker's branch, the branch will 
collect information about the executed orders and report 

3 0 that information back to the client. Sometimes, this 

information is reported in a batch at the end of the day. 
Alternatively, the securities firm may report the 
executions as they take place, by telephoning the 
institution who gave them the order. 

35 Instead of going to the booth at the floor of 

the exchange, the securities firm's broker -may place the 
order over an electronic trading system, such as the NYSE 
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Designated Order Turnaround (DOT) System. The DOT System 
routes orders directly to specialists' posts on the 
trading floor of the NYSE . The DOT System .accepts market 
orders up to 30,099 shares and limit orders up to 99,999 
5 shares. An electronic book at the specialist's post 

lists the buy and sell orders that are placed on the DOT 
System for a particular stock. When a trade takes place, 
the details of the trade are entered into the DOT System 
and made available to the securities firm that placed the 

10 order, which then must report the trade to its client. 

Alternatively, the securities firm's trader, 
instead of sending the order to the floor of an exchange, 
might place the order on an electronic market trading 
system. For example, Instinet, owned by Reuters, Ltd., 

15 is an electronic block trading system that facilitates 
the negotiation of block trades between institutional 
investors. Instinet allows the counterparts to trade 
anonymously, entering bids electronically. Instinet 
subscribers can respond to an ■order" entered into the 

20 system either by matching a displayed price or by making 
a counter bid that is transmitted instantaneously to the 
counterpart's terminal. The trades that result from 
these negotiations became public information only when 
they are executed. This procedure provides an 

25 alternative to the direct human- to -human negotiation Cf 
orders in the upstairs market or on the trading floors. 
Instinet provides a limit order book for over-the-counter 
(OTC) securities and listed securities and also provides 
inside quotes for exchange listed securities for the 

3 0 eight U.S. markets on which stocks can be traded and for 
NASDAQ listed securities. 

There are other electronic trading systems. 
Some electronic trading systems (such as DOT) 
are to facilitate trading at a particular stock exchange. 

35 Other electronic trading systems (such as Instinet) 
function independently of existing stock exchanges. 

Electronic trading systems each have their own 
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user interface and computer- to- computer interface. Each 
requires orders to be entered using differing formats, 
using different terminology and with different system 
rules. Each also quotes different prices for a 
5 particular security. It is difficult for investors, 

traders and brokers to simultaneously use these systems 
at. one time. Each electronic trading system requires a 
different computer screen and input device. Further, 
these systems do not allow investors direct access to the 
10 specialist on the floor of the exchange. For example, 
the NYSE DOT System can only be used by brokers and not 
directly by investors. 

Present electronic trading systems usually 
facilitate trading on one exchange only. The user 
15 interface and computer- to- computer interface of these 

systems may not permit orders to be held in abeyance, (or 
placed in abeyance after the order has been sent for 
execution or later execution) , allow orders to be sent 
for execution as a group but with different orders in the 
group being sent to different stock exchanges, allow an 
order or group of orders to be placed on hold for 
execution at a later time when an external event happens, 
or allow a group of orders to be placed on hold and have 
only some orders in the group sent for execution. 
25 In the execution process, the trader at the 

securities firm must make numerous decisions as to how 
and where the order is to be traded, for example, on 
which exchange, and using which execution mechanism. Not 
only do these decisions take time, but often the wrong 
30 decision is made, or the decision is made without full 

knowledge g£ the current market condition, and the client 
may not therefore obtain the best price. Traders 
typically will use the exchanges and execution mechanisms 
with which they are most familiar, rather than checking 
35 the prices on all exchanges and electronic trading 

systems . The investor typically does not or cannot make 
these decisions when using current trading systems. 



20 
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After the client has given its' order to the 
securities firm, the client is unab le to track the 
progress of the order. The client will not know if or 
when the order has been executed. If the execution does 
5 take place/ the client is not provided with the execution 
price until sometime later. The execution information 
for trades (that may have taken place on various stock 
exchanges) is not presented, to the investor in a format 
that allows the investor to easily track the execution of 
10 each order. Using current systems, it is difficult for 
the investor to correlate orders and execution 
information in real-time. At the end of the day, all 
executed orders are usually manually entered into a 
computer system so that the order can be cleared and so 
15 that the executed order can be properly recorded in the 
investor's books. In this time consuming process, many 
errors also take place. 

Order entry systems exist that enable users to 
enter orders and route these orders to a particular 
20 * electronic trading system. However, these systems 

typically are line editor systems that allow the user to 
enter only one order at a time. These systems do not 
provide real-time information as to the status of the 
order. They have limited capabilities and typically do 
25 not allow a user to manipulate orders prior to execution, 
execute more than one order at a time, or correlate order 
and execution information. Moreover, these systems do 
not have the capability to route orders to the floor of 
an exchange for manual execution or to a particular 
trading desk at a brokerage firm. 

The above described methods for trading 
securities is cumbersome, time consuming, and where human 
interaction is involved, prone to numerous errors. When 
trading securities, the above described trading systems 
35 do not give investors control over the placement and 

execution of an order. The decisions about the placement 
of an order, such as the time the order is to be sent to 
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an exchange for execution, is usually out of the control 
of the portfolio manager or investor. For example, 
because of the time delays in executing an order from 
when the decision is made by the investor to trade a 
5 particular security (many of these delays being caused by 
intermediate parties such as the securities firm) the 
• investor often does not obtain the price for the trade 
which the investor saw quoted on the investor's quote 
device when making the decision to trade. The price of a 

10 stock is constantly fluctuating. With the present 
trading systems, the investor cannot easily take 
advantage of these price fluctuations. For example, an 
investor may see a price displayed on his quote device, 
but by the time the order is actually executed, the price 

15 may have changed. 

The information about the trade prior to 
execution (for example, that a particular party is trying 
to sell 500,000 shares of IBM), particularly for large 
orders, is often spread by word of mouth before the order 

20 is actually sent to an exchange for execution. This 
enables some traders to take- advantage of this 
information before the order can be executed, resulting 
in a change in price for the stock. 

In short, when using the current systems for 

25 trading securities, the investor that wishes to make the 
trade is at a severe disadvantage. The investor, 
typically cannot control how the order is to be executed, 
where the order is to be executed or the price at which 
execution takes place . There is a large amount of human 

30 interaction in routing and obtaining execution of an 
order. (Moreover, because of the human interaction, 
brokerage firms become quite resentful when the investor 
keeps changing its order.) As obtaining execution of an 
order can be a time consuming process, the investor 

.35 cannot speedily or easily change or cancel orders as 

market conditions change. The investor is not supplied 
with real-time information about the execution of an 
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order.. Thus, the investor cannot easily modify his 
investment strategy based on real-time price information 
and real-time execution information. Expert systems or 
other forms of computer systems used to determine when to 
5 place orders cannot achieve full functionality without 
real-time execution information. 

The electronic trading systems that allow an 
investor to place an order electronically do not provide 
the investor with execution information in a format that 

10 easily allows the investor to perform its bookkeeping 
functions. For example, in the DOT system, execution 
information is provided on a separate line printer. 
Thus, a broker-dealer must manually enter the execution 
information into the bookkeeping system and cannot easily 

15 correlate orders placed with orders that were executed. 
When the execution is reported, the electronic trading 
system does not correlate the execution information with 
the order on the user interface. 

The present electronic trading systems have 

20 cumbersome user interfaces, making it difficult for users 
to enter orders quickly. 

Some systems have attempted to deal with these 
problems, but only in a partial fashion. For example, 
there have been described automated futures trading 

25 exchanges where the exchange •• computer automatically 

matches offers and bids to complete a transaction, and 
automated systems that have the purpose of replacing 
existing stock exchanges, as well as systems in which the 
system proprietor acts as a principle in the transaction. 

30 emphasis of each of these systems is to 

replace (or supplement) the functionality of existing 
stock exchanges and sources of liquidity. These systems 
do not place orders on the existing stock exchanges or 
allow investors to electronically place an order on the 

35 presently existing and various exchanges and electronic 
trading systems or to track and control the progress of 
such order until its execution. 
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None of the existing systems provide an 
integrated user interface that allows a user to directly 
place orders, and then track the progress of these 
orders, on numerous exchanges and electronic trading 
5 systems. Further, the prior art systems that allow users 
to place orders electronically do not automatically 
update the information entered, for example, by the user, 
about an order when the order is executed nor do they 
enter information into computer systems that allow 
10 further analysis and accounting to take place 
automatically. 

Summary of the Invention 

The present invention is an automated and 
15 integrated order entry and trading system that operates 
in real-time to provide a user with control over the 
management of orders. The present invention also 
efficiently reports the execution of the orders ' in real- 
time and correlates the execution information with its 
.20 order. 

The present invention is described below in the 
context of trading securities on stock exchanges and 
electronic trading systems. ' However, the invention is 
not so limited and cam be easily adapted to allow the 

25 trading of other liquid assets such as futures, 

derivatives, options, bonds, currencies and the like. 
Accordingly, where the context permits, the terms 
"securities", "stock", and "shares" when used herein 
includes other instruments that can be traded, such as,; 

30 for example, - futures, derivatives, options, bonds and 
currencies. The term "stock market , " "exchange" and 
"stock exchange" when used herein includes other markets, 
such as, for example, futures exchanges, options 
exchanges and commodity markets or other mar^u^ chat can 

35 provide a source of liquidity for instruments such as 
stocks, bonds, futures, options, derivatives and 
currencies . 
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The user of the representative embodiment 
system of - this invention is typically an investor, such 
as an institutional investor (e.g., a pension fund) but 
may also be an individual investor, a broker or other 
5 person who deals in or trades securities. As used 

herein, the term "user", or "investor" means that person 
or entity who wishes to trade or deal in securities. 

In the representative embodiment , the present 
invention includes a control engine coupled to a 

10 plurality of user workstations, each with a graphical 
user interface. Each user workstation allows for entry 
of orders. The graphical user interface of the user 
workstation displays orders that have been entered into 
the system, the status of each order and, if the order 

15 has been executed, execution details about the order. 
This information is provided on one user interface for 
all orders, irrelevant of which exchange or electronic 
trading system the order is to be or was placed. 
Accordingly, the user is able, at one glance,, to see the 

20 status of all orders. The user, interacting with the 

graphical user interface, can interactively and in real- 
time modify, suspend and cancel unexecuted orders. 

According to the present invention, the control 
engine is coupled to numerous stock exchanges, such as, 

25 for example, the Cincinnati Stock Exchange, and to the 
electronic trading systems of stock exchanges ,. such as, 
- for example, the DOT system of the New York Stock 
Exchange, the SCOREX system of the Pacific Stock Exchange 
and the MAX system of the Chicago Stock Exchange. The 

30 control engine can also be coupled to various independent 
'V electronic trading systems, such as for example, 

Instinet. The control engine can also be coupled to 
foreign stock exchanges, such as the CATS system of the 
Toronto Stock Exchange. When used herein, the term 

35 "electronic trading system" includes stock exchanges, 

such as, for example, the Cincinnati Stock Exchange, and 
the electronic trading systems of stock exchanges, such 



S0002864 



WO 95/06918 



PCI7US94/09398 



12 

as, for example, the DOT system of the New York Stock 
Exchange, and foreign stock exchanges and independent 
electronic trading systems, such as for example, 
Instinet. 

5 In the representative embodiment of the present 

invention, the control engine is also coupled to a booth 
workstation. Some stock exchanges have what may be 
described as manual trading systems. At such exchanges, 
the order may be transmitted electronically by a broker. 

10 to the floor of the exchange where it is typically 
printed on a printer and given to the broker's floor 
trader. The floor trader executes the order manually on 
the floor of the exchange in the traditional way. To 
take advantage of these manual trading systems, the. 

15 control engine is coupled to the booth workstation which 
is located, for example, on the floor of an exchange. ' 
Orders are electronically transmitted to the booth 
workstation, where the order can be printed and then 
executed manually. The booth workstation, however, need 

20 not be located on the floor of an exchange. It could be, 
for example, located on the trading desk of a trader or 
any other location where orders can be executed manually.- 

The control engine includes a switching 
function that can route an order to a particular stock ■• 

25 exchange or electronic trading system or, where 

available, to a booth workstation. In one embodiment, 
the user determines the routing of the order using -the 
graphical user interface of the user's user workstation. 

As mentioned above, also coupled to the control 

30 engine are the plurality of user workstations. Each user 
workstation is typically operated directly by an investor 
who wishes to trade in securities and perform related 
trading functions. In the representative embodiment of 
the invention, the user workstation will be located on 

35 the desk of the investor, and will be remote to the 

control engine. In the representative embodiment, the 
user workstation is. a powerful personal computer. The 
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user workstation of the representative embodiment 
includes a graphical user interface that allows the 
investor to quickly and simply enter orders (for example, 
a buy order to purchase a stock or a sell order to sell a 
5 stock) . Each order can be electronically transmitted via 
the control engine to a stock exchange or automated 
trading system. The control engine of the present 
invention routes each order, to the desired stock exchange 
or electronic trading system. 
10 The system of the present invention enables 

users to track the progress and execution of orders in* 
real-time. 

Execution information is collected by the 
control engine from each exchange or electronic trading 
* 15 system in real-time, processed and made available to the 
user at the user workstation. This information is 
provided to the control engine using various techniques. 
First, for stock exchanges and electronic trading systems 
that operate automatically such as Instinet and the 

20 Cincinnati Stock Exchange, execution information is 

provided electronically to the control engine as it is 
made available by the exchange or trading system. 
(Typically, these systems electronically match orders or 
provide for direct electronic communication between a 

25 buyer and a seller.) The control engine interacts 

directly with these electronic systems. At a second 
level, semi -automated systems, such as the NYSE DOT 
System, allow orders to be placed and transmitted 
electronically, but usually, the orders are not matched 

30 electronically. The order is usually executed or matched 
by a person, for example, by the specialist on the floor 
of an exchange. Thus, these, semi -automated systems 
communicate orders to human intermediaries that execute 
the orders. When the trade is executed, the fact of the 

35 execution and/or the execution information is manually 
entered into the semi -automated system. The control 
engine of the present invention obtains the execution 
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information from these systems as soon as it is made • 
available. Third, there are those stock exchanges, as 
described above, that have manual trading systems. The 
booth workstation on the floor of the exchange has a 
5 graphical user interface so that the floor trader can 

simply and quickly report execution of the order back to 
the control engine, for real-time transmission to the 
user workstation. Thus, the present invention routes 
orders to the booth workstation on, for example, the 

10 floor of an exchange. After the order has been worked 

manually in the traditional way, the floor trader (or the 
booth clerk) or other trader selects the order that was 
executed from the list of orders displayed on the screen 
of the booth workstation and then enters the execution 

15 information for that order. 

It is noted that the present invention allows 
for a combination of the techniques described above. For 
example, orders that are to be executed on the NYSE can 
be routed by the control engine to the NYSE DOT system or 

20 to a booth workstation on the floor of the NYSE. 

The user workstation can, if required, in 
addition to or instead of displaying the execution 
information about an order, route the execution 
information to an expert system, an application program, 

25 a neutral network or a back office application. 

Each stock exchange and electronic trading 
system' requires information to be presented to it in a 
different format. The control engine of the present 
invention formats the user's order so that it is in the 

30 correct format for each stock exchange and electronic 
trading system. 

The system of the present invention eliminates 
most human interaction from the trading process. 
Accordingly, the present invention allows each end user 

35 to have complete control throughout the execution 
process. (The only human action is that which is 
required by each stock exchange and electronic trading 
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system.) For example, if the investor decides to place 
an order on Instinet, there is no human interaction - the 
investor who wishes to make a trade simply, enters the 
order at the investor's user workstation and the control ■ 
5 engine routes the order to Instinet. If the investor 
decides to place an order on the NYSE DOT system, the 
only human interaction is that required by the DOT 
System, i.e., that of the specialist on the floor of the 
exchange. Accordingly, human error is reduced, and 

10 orders can be placed by the user and executed as fast as 
the stock exchange or electronic trading system allows. 
There is no manual intervention between the user entering 
an order into the system of the present invention and the 
placing of the order on the required stock exchange or 

15 electronic trading system. 

Further, the system allows executed orders to 
be reported in real-time to the user workstation (or the 
user) that placed the order. For example, when an order 
is placed on the NYSE DOT System and is then executed, 

20 instead of the execution being reported to a broker over 
a different system to that by which the broker placed the 
order (and then waiting while the broker telephones the 
investor with the execution information) , the control 
engine of the present invention receives the execution 

25 report from the NYSE DOT System and immediately and in 
real-time provides this information to the user at the 
same interface on which the user placed the order. 
Moreover, the system of the present invention 
automatically correlates the execution information with 

30 the order. 

Even when the trade is executed on the floor of 
an exchange, because the floor broker has a booth 
workstation in the floor booth, the booth clerk can 
immediately enter details about the executed order into 
35 the booth workstation. This execution information is 
automatically transmitted to the control engine. The 
control engine then reports this execution information to 
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the user workstation that placed the order, for display 
at the user workstation correlated with the order as 
described above. 

The graphical user interface of the user 
5 workstation shows orders that have been entered into the 
system. The user interf ace also allows the' user to enter 
information about orders not executed using the system of 
the present invention, for example, to take advantage of 
the back office features of the present invention 

10 described below. The user interface shows the status of 
each order, and if the order has been executed, execution 
information about the order. The order information for 
an order can be displayed on one line of the screen and 
the execution information can be displayed on the same 

15 line to increase ease of use. The execution information 
can include execution information received from an 
exchange, from an electronic trading system, from a booth 
workstation, or entered manually by the user if the. trade 
took place outside, the system of the present invention. 

20 . The graphical user interface provided on the 

user workstation of the present invention allows the user 
to sort and display the order information and execution 
information using sophisticated display techniques 
unavailable on other order entry systems. The user 

25 workstation of the present invention further allows the 
user to simultaneously send a group of orders to one or 
more exchanges for execution, to prepare orders that can 
be sent for execution at a later time and to enter orders 
using a minimum of keystrokes. Further, the user 

30 workstation of the present invention can be coupled to an 
on-line source of price information. The user 
workstation will then allow the user to prepare an order 
(or a group of orders) to be sent automatically for 
execution on the happening of an external event. 

35 Moreover, the fact that no human intervention 

by a broker or intermediary need be involved improves the 
confidentiality of information about orders sent for 
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execution.. For example, for an order that is traded 
through the DOT system, the only information that is 
disclosed is the order size and price. The identity of 
the user is kept confidential - the control engine does 
not disclose the identity of the' user (unless the user 
requires it) , and all the DOT system knows is that the 
order is being sent by the control engine of the present 
invention. As the control engine can process and route 
orders for many users at the same time, knowledge about 
each user's trades is not disclosed. The system gives 
the user the maximum information available about a trade 
without giving away any unnecessary information. 

The present invention allows users to 
communicate order and execution information with each 
15 other. For example, an order may be entered by one user 
at one user workstation and information about the order 
and. execution information for the order may be displayed 
at a second user workstation. This allows, for example, 
one user workstation to supervise orders and executions. 
20 for many traders, e.g., to supervise all traders in a 
firm. 

Post -execution enhancement features allow the 
user to simply and efficiently book each executed order 
in the relevant account or accounts without having to 
reenter the execution information. Further, the system 
of the present invention automatically interfaces with " 
the clearing system of the brokerage house so that the 
executed orders can be cleared without the need for 
reentry of execution details, thus reducing errors. 

Accordingly, the present invention can provide 
v investors with direct access to many pools of liquidity 
for U.S. and foreign securities, including primary, 
secondary and third market sources. The system of the 
present invention can route and execute trades for many 
35 different securities at many sources of liquidity 

including primary and regional exchanges, NASD dealers 
and market makers, option exchanges and the third market. 
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The system of the present invention allows investors to 
enter, change and monitor single, multiple or list 
orders. The investor can select the specific routing for 
an order. The present invention instantaneously updates 
the status of orders. It provides a detailed audit trail 
for each action or event in the execution process. The 
present invention enables multiple and list orders to be 
sent simultaneously to different liquidity sources and 
enables investors to enter orders that are directly sent 
to exchange specialists and market makers in seconds and 
to thereafter receive a report immediately upon execution 
of the order. 

The integrated user interface of the present 
invention gives the user control over the placement, 

15 timing and execution of orders . Information about orders 
and executions can be entered and displayed in a single 
format, regardless of where the order is placed or how 
execution information is provided about the order. The 
content and format of the display of this information can 

2 0 be determined by the user, not by any external system. 
■ Accordingly, the present invention 
significantly improves the speed at which orders can be 
placed on multiple systems and the speed at which 
execution information can be provided to the investor. 

25 The user is provided with direct and 

instantaneous access to many sources of liquidity. 
Additionally, the user workstation of the present 
invention, by integrating real-time price, order, and 
real-time execution information, for many stocks traded 

30 on various exchanges (and if required, displaying this 
information all on _the one computer screen, or on more 
than one computer screen. if desired) allows the user to 
micro-manage the user's portfolio. Accordingly, 
utilizing the real-time information and the direct access 

35 features of the present invention, the user can quickly 
submit orders for execution, examine feedback concerning 
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the order as well as other external information, either 
manually or via a computer, and if required, cancel or 
modify the order or create new orders. 

5 

Brief Description of the Drawings 

Fig. 1 is an illustration in block diagram form 
of a representative embodiment of the system of the 
10 present invent ion v 

Fig. 1A is a table illustrating, as an example, 
some sources of liquidity to which the control engine "of 
Fig. 1 can be coupled. 

Fig. 2 is am illustration in block diagram form 
15 of a representative embodiment of an example network 
configuration for the system of the present invention. 

Fig. 3 is an illustration in block diagram form 
of a representative embodiment of internal system 
architecture of the control engine of Fig. l. 
20 Fig. 4 is an illustration in block diagram form 

the processes that are carried out by the user 
workstation of Fig. 1. 

Fig. 5 is an order management toolbar displayed 
at the user workstation of Fig. l. 
25 Fig. 6 is an order entry window displayed at 

the user workstation of Fig: 1. 

Fig. 7 is a detailed order entry window 
displayed at the user workstation of Fig. 1. 

Fig. 8 is a block diagram illustrating the 
30 functions performed by the order management process of 
Fig. 4. r\ 

Fig. 9 is a Fast Order Entry window displayed 
at the user workstation of Fig. 1. 

Fig. 10 is a book- view window screen display. 
35 Fig. 11 is an execution window screen display. 

Fig. 12 is a book- view toolbar displayed at the 
user workstation of Fig. 1. 
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Fig. 13 is a block diagram illustrating the 
functions performed by the book-view process of Fig. 4. 
Fig. 14 is a list window screen display. 
Fig. 15 is an Order Alert window screen 

5 display. 

Fig. 16 is a diagram in flow chart form 
illustrating the steps performed by a typical CTCI 
routine of the control engine of Fig. l. 

Fig. 17 is a diagram in flow chart form 
10 illustrating -the steps performed by a print capture 
routine of the control engine of Fig. 1. 

Fig. 18 is a diagram in flow chart form 
illustrating the steps performed by the execution routine 
of the control engine of Fig. l. 

15 Fi 9- 19 is an example of a typical end of day 

report . 

Detailed Description 

Turning now to the drawings, and initially Fig. 

20 1, there is illustrated in block diagram form a* 

representative embodiment of the system of the present 
invention. A control engine 2 is coupled to at least one 
user workstation 4. At the user workstation 4 investors 
are able to enter orders, for example, orders to buy and 

25 sell securities, using a graphical user interface. The 
investor is able to perform other functions at the user 
workstation 4 related to trading of securities, discussed 
in detail below. It is anticipated that the user 
workstation 4 will be located on the desk of an investor 

3 0 who wishes to trade securities. In the representative 

embodiment of the present invention, the user workstation 
may be a personal computer, such as, for example, an IBM 
personal computer with an Intel 486 processor running at 
66 MHz and a color monitor. In an alternative 

35 embodiment, the. user workstation 4 can also accept 
instructions from the user using voice recognition 
techniques and provide information using a voice 
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.synthesizer. The user workstation 4 is capable of 
performing additional functions other than required by 
the system of the present invention. Accordingly, the 
user workstation 4 can execute other application programs 
5 such as word processing and spreadsheet programs. In the 
representative embodiment, the user workstation 4 will be 
coupled to a source of on-line price and/or market 
information 16. The user workstation 4 will accordingly 
execute an application program that receives, formats and 
10 is capable of analyzing price and/or market information. 
In the representative embodiment, this application 
program may be the commercially available P.C. Quote 
Program available from P.C. Quote, Inc. of Chicago, 
Illinois. 

15 In the representative embodiment, the graphical 

user interface displayed on the color monitor of the user 
workstation 4 and the flow of data between the user 
workstation 4 and the control engine 2 is controlled by 
software stored on a memory device in the user 

20 workstation 4. 

The control engine 2 is further coupled to 
existing sources of liquidity such as stock markets and 
automated trading systems. For example, the control 
engine 2 is coupled to the Computer-To-Computer Interface 

25 (CTCI) of each desired stock-market trading system or 
electronic trading system. As shown in Fig. 1, the 
control engine 2 is coupled to the New York Stock 
Exchange DOT System 8, Instinet 10 and the Cincinnati 
Stock Exchange (CSE) 12. Fig. l is illustrative only, as 

30 it is contemplated that the control engine 2 of the 
present invention will be linked to most, if not all, 
stock exchanges and other sources of liquidity, including 
exchanges in other countries. For example, the control 
engine 2 is also coupled to the Pacific Stock Exchange 

35 (not^ shown) and the American Stock Exchange (not shown). 
The table illustrated in Fig. ia lists, as an example, 
some sources of liquidity to which the control engine 2 
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is coupled, as well as some of the order requirements of 
those systems. 

.The control engine 2 may also be coupled to a 
commercial order routing service (not shown) such as the 
5 order routing service provided by Bridge Data, at St. 

Louis, Missouri. Commercial order routing services allow 
users to enter an order using a dumb terminal that is 
coupled to a central switch. The central switch sends 
the order to the exchange selected by the user. It is 

10 noted that most commercial order routing services require 
that each order be entered by the user one order at a 
time, typically using a line editor to enter the order. 
When requested by the user, the order routing service 
will supply information as to the execution of an order. 

15 This information is typically provided on a printer 
separate to the dumb terminal. The connection to a 
commercial order routing service allows the control 
engine 2 of the present invention to obtain indirect 
access to the sources of liquidity for use if a direct 

20 link from the control engine 2 to a particular exchange 
fails or becomes overloaded. 

The control engine 2 (as explained in more 
detail below and with reference to Fig. 3) receives 
orders from the user workstation 4. The control engine 2 

25 will examine the .order to determine the exchange or 
automated trading system to -which it must route the 
order. The control engine 2 will xeformat the order so 
that the order complies with the format required by the 
stock exchange or automated trading system to which the 

30 order is to be routed. For example, the control engine 2 
will format orders that are to be sent to Instinet 10 so 
as to comply with the Instinet computer interface 
protocols described in the document "Customer Computer to 
Instinet Application Layout Specif ication" version 4.1, 

35 published September 11, 1992 by Instinet Corporation. 

For an order that is to be placed on the Cincinnati Stock 
Exchange 12, the control engine 2 formats the order so 
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that "it, complies with the message format described in 
"Computer Interface Manual* April 6, 199 3,. published by 
the Cincinnati Stock Exchange. The Cincinnati Stock 
Exchange calls their system the National Securities 
5 Trading System. According to the system of the present 
invention, orders can be routed to other ..exchanges and ' 
automated trading systems, such as the NYSE DOT System 8. 
The control engine 2 will accordingly format each order 
so that it complies with the interface and trading rules 

10 of the system to which the order is to be routed. 

Moreover, the control engine will interpret and 
manipulate the order information supplied by the user at 
the user workstation 4 so that it is compatible with the 
system where the order is routed but so that the order 

15 complies with the user's instructions. For example, CSE 
12 does not allow -good until" orders. (Some exchanges 
and electronic trading systems do, however, allow, "good 
until" orders.) If the user requires a "good until" 
order on CSE 12, the control engine 2 will accept that 

20 order, convert it to an unrestricted order acceptable by 
CSE 12, but will automatically .cancel the order at the 
"until" time requested by the user. Thus, the user * 
receives full functionality without having to know or 
' understand individual system requirements . 

25 Orders' can be split between exchanges and 

automated trading systems. For example, if a sell order 
of 5,000 shares is sent for execution, the user may 
decide that the order is to be split. Thus, for example, 
3000 shares may be sent to Instinet 10 for sale and 2000 

30 shares may be sent to CSE for sale. 

The control engine 2 can be at a remote 
location with respefct to both the user workstation 4 and 
the stock exchanges and automated trading systems 8-12. 

Also coupled to the control engine 2 is a booth 

35 workstation 14. The booth workstation 14 in the 

representative embodiment is a personal computer with an 
attached printer and a graphical user interface . 
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Typically, the booth workstation 14 will be located at 
the trading booth of a securities firm on the floor of an 
exchange or to their OTC trading department. An investor 
operating the user workstation 4 may decide to route an 
order directly to a floor broker on the floor of a 
specified stock exchange, or OTC trading desk, or options 
floor. The investor will enter the order at the user 
workstation 4 nominating a floor broker as the recipient 
of the order and then transmit the order to the control 
engine 2 which routes the order to the correct booth 
workstation 14 . At the booth workstation 14 , the order 
can be physically printed on the attached printer and 
given to a floor trader who will execute the order 
manually . 

15 However, it is noted that the booth workstation 

14 need not be located at a trading booth on the floor of 
- an exchange. The booth workstation 14 can be placed at 
any location, such as, for example, the desk of a 
particular trader at a brokerage firm, at the trading 
desk of an institutional investor or at any other desired 
location where it may be desirable to route orders. This 
allows investors to route orders in real-time and to 
locations that previously may not have been directly 
accessible to the investor and receive execution 
25 information back in real-time on the same workstation or 
expert system. 

Each stock exchange and automated trading 
system has the. capability to report the execution of an 
order. In the system of the present invention, the 

30 control engine 2 is designed to receive the execution 
information electronically. For example, Instinet 10 
will electronically and automatically report executed 
orders when required by a user, as well as other 
execution information. The control engine 2 accordingly 

35 requests and receives these execution reports 
electronically, and then transmits them to the 
appropriate user workstation 4 for display. Semi- 
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automated trading systems, such as the NYSE DOT System 8, 
also have reporting capabilities. For example, a broker 
that has access to the DOT System 8 usually obtains 
execution reports from a system that reports executions 
5 to a printer. In these systems, the execution 

information from the execution report is not displayed on 
the broker's computer screen correlated with the order 
information. As discussed in more detail below, the 
control engine 2 of the present invention obtains the 

10 execution information as soon as it is available, 

reformats that information and transmits it for display 
at the user workstation .4 correlated with the 
corresponding order information. 

When an order is transmitted to the booth 

15 workstation 14, it is executed manually. The graphical 
user interface of the booth workstation 14 allows the 
floor trader to quickly and efficiently enter the details 
of the execution. These execution details are 
transmitted from the booth workstation 14 to the control 

20 engine 2 for transmission and display at the user 
workstation 4 . 

Accordingly, no matter where the order is 
placed, execution information is displayed to the 
investor at the user workstation 4 as soon as it is made 

25 available, for example, by the stock exchange, automated 
trading system or floor broker. Moreover, as explained 
in detail below, the execution information for an order 
is correlated and displayed with its corresponding order. 

Turning now to Fig. 2, there is illustrated in 

3 0 block diagram form a further embodiment of the system of 
the present invention. As shown in Fig. 2\ many user 
workstations 4A to 4G are coupled to the control engine 
2 . The user workstations may be coupled to the control 
engine 2 in various ways. For example, user workstation 

35 4A is coupled ^to the control engine 2 via a modem or DSU 
26. User workstation 4B and user workstation 4C are 
coupled to a private wide area network 22, dedicated to 
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the system of the present invention. The private wide 
area network 22 is coupled to the control engine 2. User 
workstations 4D to 4F are coupled to a local area network 
20. This local area network arrangement is useful where 
5 a number of user workstations 4 are to be located near 
each other, for example, in one office of an 
institutional investor. The local area network 20 is 
itself coupled to the control engine 2, in this example 
via the private wide area network 22. User workstation 
10 4G is coupled to a public wide area network 24 which is 
in turn coupled to a modem or DSU 25 of the control 
engine 2 . 

Typically, communication between a user 
workstation 4 and the control engine 2 is via 

15 asynchronous or digital dialing lines. As ^nown above, 
as more than one user workstation may be located at one 
site and coupled to the control engine 2 f it may be 
preferable to provide access to the control engine 2 via 
a leased line with a LAN bridge at the control engine 2. 

20. Protocols that are supported in the representative 
embodiment are TCP\IP and NetBeui . 

Additionally, a computerized model, neural 
network, or expert system 9 may be coupled to one of the 
user workstations 4 of the present invention. The model, 

25 neural network or expert system 9 may make the 

determination as to when to enter an order or group of 
orders, send an order or group of orders for execution or 
cancel an order or group of orders {or all three at 
once) . Because the present invention is coupled to many 

30 exchanges and automated trading systems, the speed of 
reacting to the model's or expert's systems 
recommendations is enhanced. Moreover, the model, neural 
network or expert system can receive execution 
information from the user workstation 4 in real-time and 

35 use the execution information as a parameter in making 
decisions. 
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As discussed in mare detail below, the control 
engine 2 of the present invention obtains the execution 
information as soon as it is available from automated 
trading systems. The control engine 2 may store the 
5 execution information in a database (6 of Fig. 3) . The 
control engine may also correlate the execution 
information for an order with the informat ion . about the 
order. The control engine transmits the execution 
information (or makes the execution information 

10 available) for display at the user workstation 4A-4G from 
which the control engine 2 received the order. 

It is noted that Fig. 2 is illustrative only, 
and other network configurations, and combinations 
thereof, can be used to couple user workstations 4 to the 

15 control engine 2 . 

Turning now to Fig. 3, there is illustrated in 
block diagram form an exemplary embodiment of the 
internal system architecture of the control engine 2. 
The control engine 2 may be a mainframe computer coupled 

20 to various input/output devices and bridges. However, in 
the representative embodiment, the control engine 2 has a 
local area network system structure. As shown in Fig. 3, 
the user workstation 4 is- coupled to a private wide area 
network 22 which is in turn coupled to a local area 

25 network bridge 32. The local area network bridge 32 is 
coupled to a local area network 30. of the control engine 
2. Also coupled to the local area network 3 0 of the 
control engine 2 is an execution processor 34, a file 
server 36 and a database server 38. ■ The execution 

30 processor 34 is responsible for the control and routing 
(to the correct user workstation 4) of the execution 
information supplied by the exchanges 8-12 and the booth 
workstation 14 when an. order is executed. The file 
server 36 stores some of the information required for the 

35 operation of the control engine 2. (However, if the 
processors used by the control engine 2 have internal 
memory, this information could t?e stored locally.) The 
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database server 38 will control the operation of a 
. database S. As shown in Fig. 3, the database 6 is 

internal to the control engine 2. The database 6 may be 
located on the local area network .30 of the control 
5 engine 2. However, the database 6 may also be located 

external to the control engine 2. For example, there may 
be two databases coupled to or part of the control engine 
2, one external to the control engine 2 for backup 
purposes. The database 6 stores information transmitted 

10 from. each user workstation 4 to the control engine 2. 
The database 6 also stores information received by the 
control engine 2 and booth workstations 14. The 
information is stored in the database 6 in table format, 
described in. more detail below. 

15 In the representative embodiment, an Instinet 

processor 46 is coupled to the LAN 3 0 and a multiplexor 
.42. The multiplexor 42 is coupled to the Instinet 10 
CTCI. The Instinet processor 46 and multiplexor 42 allow 
communication to take place between Instinet 10 and the 

20 control engine 2. The formatting of orders for the 

Instinet 10 system so that they comply with the Instinet 
protocol is carried out by the Instinet processor 46. 

A CSE Out processor 48 is coupled to a modem 40 
which is coupled to the National Securities Trading 

25 System CTCI of the Cincinnati Stock Exchange 12. 

Further, a CSE In processor 50 is also coupled to the LAN 
30 and the modem 40. There is a two-way communication 
line 4 8A between the CSE Out processor and the modem 40. 
The two-way communication line 48A allows the CSE Out 

30 processor 48 to place orders on the Cincinnati Stock 

Exchange 12 and receive communication information from 
the Cincinnati Stock Exchange confirming that 
communications between the control engine 2 and the 
Cincinnati Stock Exchange 12 were successful. There is a 

35 one-way communication line 5 OA from the modem 40 to the 
CSE In processor 50. The one-way communication line 50A 
receives information from the Cincinnati Stock Exchange 
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12 as -to. the execution and status of an order placed on 
that exchange. As the Cincinnati Stock Exchange 12 
reports status and execution of an" order to a line 
printer, the CSE In processor 50 performs the function of 
5 capturing the information that the Cincinnati Stock 

.Exchange 12. transmits, and formatting it so that it can 
be stored in the database 6 of the present invention. 
This information is thereafter transmitted by the CSE In 
processor 50 via the LAN 30 to the database G and 

10 thereafter for display on the appropriate user 
workstation 4 . 

A similar arrangement to that described above 
with reference to the Cincinnati Stock Exchange 12 allows 
the control engine 2 to communicate with the NYSE DOT 

15 System 8. A DOT Out processor 52 places orders via a 
multiplexor 44 on the NYSE DOT System 8 and receives 
confirmation that communications have correctly taken 
place between the NYSE DOT System 8 and the DOT Out 
processor ,52. The NYSE DOT System 8 sends execution 

20 information via the multiplexor 44 to a DOT In processor 
54, which is also coupled to the local area network 30. 
The DOT In processor 54 captures the print information 
sent by the NYSE DOT System 8, reformats this information 
and places it in the database 6. The print capture 

25 process that is performed by the DOT In processor 54 (as 
well as the CSE In processor 50) is discussed in more 
detail with reference to Fig. 17 below. 

As shown in Fig. 3, a series of computers are 
networked to provide the functionality performed by the 

30 control engine 2. The control engine 2 is designed to be 
open ended, so that more exchanges can be easily added. 

In the representative embodiment, there are 
four overall processes that take place at the control 
engine 2. First, a communication process executed by the 

35. database server 3 8 coordinates communications between the 
control engine 2 and the user workstations 4 . Second, a 
Computer-To- Computer Interface process (the CTCI routine) 
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directly handles communications to the stock exchanges 
and automated trading systems. There is one CTCI routine 
for each stock exchange or automated trading system. 
Third, a print capture process (the print capture 
5 routines) collects information returned from certain 
exchanges and from certain automated trading systems . 
Fourth, an execution process (the execution routine), 
carried out by the execution processor 34, processes the 
execution information collected by the print capture 
10 process for transmission to the appropriate workstation 
that transmitted the related order to the control engine 
2. 

The control engine 2 of the present invention 
has a database 6 that is organized into tables of 

15 information. One possible table structure is illustrated 
in Appendix A. Each user workstation 4 is able to access 
(directly or indirectly) the tables of information in the 
database 4 . Each entry in the database 4 accordingly 
identifies the user or users who can access that entry. 

20 Appendix A describes each table in the database ■ 

6 of the representative embodiment of the present 
invention. Each table is described using well known 
notation. Each table in the database 6 has a table name. 
Each column in the table is identified with a column name 

25 and data type. In the representative embodiment, the 

tables are SQL (Structured Query Language) tables. The 
column or columns that comprise a key are marked with a 
key indicator, for example, "AKO" next to a column name 
identifies that the column is a key or part of a key. 

30 The following is a summary of each table in 

Appendix A. Az^ Account_Trans table stores account 
numbers, as assigned by a designed clearing entity, for 
transactions. The table is cleared when read. Thus, the 
Account_Trans table in effect stores account numbers for 

35 accounts that have been updated since the last read. A 
Code table stores control information, including, for 
example, the next available tag number. A Comm_reprt 
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table stores information relevant to commission charged 
by the designated clearing entity, discussed below with 
respect to the Trade 'Blotter function. A Custinfo table 
holds information on account break-downs of trades. A 
5 CustMast . table holds master information relevant to each 
customer account. An Execution table stores static 
information about each trade. A NWBBal table stores 
downloaded account balances from a nominated broker, and 
is used by a Broker application, discussed below. A 

10 NWBPos table stores downloaded position information from 
the nominated broker, and is used by the Broker 
application, discussed below. A NWBTrans table stores 
downloaded transaction information from the nominated 
broker, and is used by the Broker application, discussed 

15 below. A Prices table holds prices for a stock, stored 
by ticker symbol. A Rlzd_Report table stores realized 
information for an account. (Realized information is the 
profit or loss actually realized.) A Securities table 
stores ticker symbols for each stock. A SIS Compare table 

20 holds comparisons between the user's trading position and 
the nominated broker's position. An SSplit. table stores 
stock split information. A Symbol sJZhanged table stores 
ticker symbols that have changed. A Trade table, 
discussed below, holds static and dynamic information 

25 about each order and it is cleared at the end of each 

day, or other regular period. A Trade_Audit table holds 
copies of images of the Trade table to record the 
progress of the execution of an order. A Trade_Blotter 
table holds Blotter information. A Transactions table 

30 stores the transaction information when it is cleared 

from the Trade table. An Unrlzd_Bal table stores money 
balances for each account downloaded from the designated 
broker. An Unrlzd_Report table holds unrealized 
positions information. 

35 Further, in the representative embodiment, a 

series of tables exists for each CTCI interface to an 
exchange or automated trading system. For example, 
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tables labeled "CSE" relate to information sent to or 
received from the Cincinnati Stock Exchange 12. Tables 
labeled *! INET" relate to information sent to or received 
from Instinet 10. Tables labeled "SIS ■ relate to 
5 information sent to or received from the NYSE DOT system. 
Thus., a QCSE table holds a queue of orders, modifications 
and cancels for the Cincinnati Stock Exchange. A CSE CX 
table holds CSE CTCI reference numbers .to cross reference 
the tag number and can be used, for example, to correlate 

10 order information with execution information. A CSE Prn 
table is the CSE CTCI print capture table that receives, 
for example, execution reports from the CSE . When a CTCI 
is added to the system, for example, to add a link to 
another exchange or automated trading system, more tables 

15 are added to the database 6. 

To further elaborate, the following is a 
description of some of the columns for the Trade table of 
the representative embodiment of the present invention. 
Each row in the table represents one trade. Tag is the 

20 internal control number to identify the trade. Tag_Seq 
, is* always zero in the trade table. Timestamp is the 
internal Date and Time of last modification. Mod_Stamp 
is an identifier for the user workstation 4 (and the 
user) that last modified this trade. Inst_Type valid 

25 entries are ST, BN, OP and OT (Stock, Bond, Option and 
Other). Side valid entries are BY, SL, CS and SS (Buy, 
Sell, Cover Short and Sell Short) . Qty is the quantity 
of a trade, e.g. a volume of shares. Price can have a 
whole portion and a fraction. (The fraction can be a 

30 decimal number up to five positions) . Gun is an 

arbitrary identifying code for orders so that they can be 
processed as a group. Mkt_Ind, if set to True indicates 
a Market order. . (If MKT_IND is True, the Price field 
must be nil.) Solicited_Ind, if set to True indicates 

35 the order was solicited. Exchange is an internal code 
• representing where this order (or part of an order) was 
sent. 
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Org_Date_Time is the internal Date and Time 
this order was originally sent to the exchange. Status 
records execution information, i.e., the status of an 
order, such as, for example, HLD, NEW, ACT, EXC, SUS, 
5 CAN, CFO (i.e., Held, New Order not yet confirmed by the 
floor, Active Order, Suspended, Canceled, Canceled Former 
Order) . Op_Open_Ind, if True indicates Open, False 
indicates Close. Op_Put_Ind, if .True indicates Put, 
False indicates Call. Con_Code indicates the specific 

10 conditions: DAY, GTC, FOK, IMM, 00, NH, MOC, LOC, GU. 
{Day,. Good till Canceled, Fill or Kill, Immediate, ' 
Opening Only, Not Held, Market on Close, Limit on Close, 
Good Until) . Con_Gt_Type indicates what type of data is 
in the CON_GT_LIMIT field. (1 - Date, 2 - Specific Time, 

15 3 ■ Number of Minutes) . This field and CON_GT_LIMIT are 
only used if the C0N_C0DE is GU. PegJTo indicates the 
type of pegging:. MKT, LST, SRI, BST, MID, OPN. (to: 
Market, Last Price, Primary Market, Best, Middle, 
Opening) . Peg_Limit is am optional Limit Field, 

20 comprising, e.g. LST, MID, BID, ASK, CLS. (Last Price, 
Middle, Asking, Closing) . Peg_Plus_Ind, if True 
indicates a Plus Delta Price is in the PEG_PRICE field. 
False indicate a Negative Delta Price. Peg_Price has a 
Whole portion and a Fraction. 

25 The following is a description of some of the 

columns for the Custlnfo table in the representative 
embodiment of the present invention. Each row in the 
table represents one trade where the trade has customer 
information assigned. Cus_Tag_Seq is always zero in the 

30 costpmer Tag table. Cus_Acct is an account number, 

normally 8 characters long. Cus_Acct_Seq is a sequence 
number, beginning at 1, that allows multiple occurrences 
of the same CUS_ACCT number on the same TAG and TAG_SEQ. 
Cus_T valid entries are 0, 1, 2 and 3. An entry of 0 

35 represents a firm trade. An entry of^ 1 represents a cash 
trade. An entry of 2 represents a margin trade. An 
entry of 3 represents a short trade. An entry of 3 is 
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forced when the Side is CS or SS. Cus_Avg_Elig_lnd, if 
True indicates this row is eligible for price averaging, 
Cus_Code is a "Short Name" for the customer. 

The LAN 30 of the control engine 2 utilizes 
5 Microsoft LAN Manager 2.2, and the NetBEUI Protocol as 
the default communications protocol. As an alternative 
communications protocol, the LAN 30 also utilizes the 
TCP/IP protocol, including Microsoft's Extensions to 
TCP/IP package and a SOCKETS interface. 

10 The database server 3 8 utilizes the Windows NT 

operating system, including Microsoft's SQL Server 4.2 
and utilizes an Eagle NE3200 network card. 

The LAN bridge 32 may be a Develcon Local 
Ethernet Bridge, which has protocol transparent operation 

15 in networks supporting protocols including OSI, XNS, 
TCP/IP, DeCnet and NetWare. 

The Computer- To- Computer interface (CTCI) 
processors, such as 46, 48, 50, 52 and 54, run on 
diskless workstations. 

20 The system of the present invention utilizes 

object oriented programming techniques. 

Turning now to Fig. 4, there is illustrated in 
block diagram form the processes that are carried out at 
the user workstation 4. These processes will be 

25 described in more detail below. In summary, the processes 
performed at the user workstation 4 include an order 
management process 100, a book view process 200, a fast 
order entry process 300, a list process 400, a DDE 
(Dynamic Data Exchange) . manager process 500 and, 

30 optionally, a DDE compatible spreadsheet process 600. 

In the representative embodiment, the user 
workstation 4 utilizes Microsoft's DOS Operating System, 
version 5.0 or greater (MS-DOS). Where user workstations 
4 are coupled together over a LAN 20, they may utilize 

35 Microsoft's Windows NT operating system or the Microsoft 
Windows For Workgroups operating system. In coupling the 
user workstations 4 to the control engine 2, the 
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representative embodiment of the present invention may 
utilize Microsoft's LAN Manager Remote Access Server 1.1 
(Dial -In Connectivity Software) . It is noted that other 
operating systems, such as OS/2 and the Unix Operating 
5 System may also be used. In the representative 

embodiment the Microsoft Windows NT operating system is 
used; thus the screen displays and the windows are in the 
Microsoft Windows NT format and are created using the 
Microsoft Windows NT toolkit, commercially available from 

10 Microsoft Corporation. Accordingly, the user will 

typically enter and manipulate information in the window 
displayed on the user workstation 4, using a keyboard and 
a mouse. However, other data entry devices may be used, 
for example, a touch screen, a voice recognition input 

15 device, or a trackball. 

Turning now to Fig. 5, there is illustrated a 
toolbar that is displayed. on the screen of the user 
workstation 4 by the order management process 100. The 
toolbar illustrated in Fig. 5 is an order management 

20 toolbar 130. 

The order management tool bar 130 is part of 
the graphical user interface that allows the investor at 
the user workstation 4 to interact with the order 
management process 100. On the toolbar are a number of 

25 buttons' and boxes. A button, when selected by the user, 
causes am action to happen. A button can be selected for 
example, by placing the cursor on the button and clicking 
the mouse. A box allows the user to enter information. 
Information can be entered by placing the cursor in the 

30 box and typing the information from the keyboard. 

Information can also be placed in the box by placing the 
cursor on a down arrow next to the box which will cause 
the display of various options that may be entered into 
the box. The user can then select one of those options. 

35 The order management toolbar 130 in the 

representative embodiment comprises a number of buttons, 
including a Write New Order Button 132, a File Changes 

S0002888 



WO 95/06918 PCT/US94/09398 



36 

Button 134 , a File Changes . & Hide Button 136 , a Close 
Current Order Button 13 8, an Undo Button 140, and an 
Enter Executed Order button 147. 

The Write New Order Button 132 allows the user 
5 to call up a window so that a new order can be entered. 
When the user selects the Write New Order Button 132, an 
order entry window 160 (as shown in FiG. 6 below) is 
displayed on the screen along with the order management 
toolbar 13 0. 

10 v The File Changes Button 134 allows a user to 

change details concerning the current order. The current 
order is the order that is displayed on the screen in the 
highlighted order entry window 160. 

The File Changes & Hide Button 13 6 allows the 

15 user to apply enter changes to the current , order and 
then, after the changes have been made to the current 
order, hide the current order. 

The Closed Current Order Button 13 8 allows the 
user to close the current order window. For example, by 

20 clicking on the Closed Current Order Button 13 8, the 

order entry window 160 of Fig. 6 will be removed from the 
screen. The Undo Button 140 allows the user to undo 
changes made to the current order. 

The Enter Executed Order Button 147 enables the 

25 user to enter both order and execution information for 
orders that were placed for execution by a system or 
method other than the control engine 2 and have been 
executed. By clicking on the Enter Executed Order Button 
147, a window is opened that allows the user to enter 

3 0 , both order and execution information for an order. This 
feature allows the information concerning orders placed 
using other systems to be included in the database 6, for 
example, to take advantage of the back office features of 
. the present invention, discussed below. 

35 The order management toolbar 130 includes a 

customer account code box 154. The customer account code 
box 154 allows the user to enter a customer account code. 
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The customer account code may include words, numbers- or . 
symbols.' For example, as shown in Fig. 5, the customer 
account code is "Pension Fund A," which may be, for 
example, the name of an institution or a particular 
5 pension fund managed by an institution. 

A CTCI routing box 156 (also called a computer 
to computer interface routing box) allows the user to 
select the routing destination for an order. When the 
user clicks on this box, there will be displayed a list 

10 of all available routing destinations. As shown in the 
CTCI routing' box 156 in Fig. 5, the selected routing is 
"CSE" (which stands for the Cincinnati Stock Exchange) . 
The order management toolbar 130 also has a number of 
Quick Route Orders Buttons 150. Each Quick Route Orders 

15 Button 15 0 is predetermined and is dedicated to a 

particular routing, such as, for example, the Cincinnati 
Stock Exchange or Instinet. If the user selects a Quick 
Route Orders Button 150, that routing will automatically 
be displayed in the CTCI Routing Box 156. 

20 W 11511 the user selects a Quick Route Orders 

Button 150, the selected order will be sent for execution 
to the selected destination, via the control engine 2. 
When the user selects a routing destination, the user 
will then be prompted to confirm that this is. the correct 

25 destination for the order. If it is, the order will then 
be sent for execution to that destination via the control 
engine 2 . 

The order management toolbar 130 also comprises 
a Manual Exchange Box 152 . The user can select the 

30 Manual Exchange Box 153 to enter details about a manual 
exchange. A manual exchange is where^he user has a 
trade executed manually, i.e, in the traditional fashion 
and not using the routing features of the control engine 
2. To keep track of all orders that the user places, and 

35 particularly, to take advantage of the back office 

features of the present invention that are discussed 
below, the user can enter details about such orders. 
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Details about a manual execution are stored in the 
database 4 , but are not routed by the control engine 2 to 
an exchange or automated trading system. Details about a 
manual execution can be integrated into the back office 
5 features of the present invention and into the expert 
system 9 or an analytics program. 

A Price Modification Box 158 contains the 
current price for the current order plus five fractions 
above and below the curxent price. The fractions are in 

10 the same unit as the order price. 

The order management toolbar 130 further 
comprises a Contexts Sensitive Help Button 14 6 and an 
Exit Button 13 8. If the user selects the Exit Button 
138, the user will terminate the order management process 

15 100 and the user workstation 4 will cease display of the 
order management toolbar 130. 

The order mana gement toolbar 130 also comprises 
an Add Execution Button 142 and a Delete Execution Button 
134. The Add Execution Button allows a user to add 

20 execution information to the current order. If the user 
selects the Add Execution Button 142, the user will be 
able to add information to and modify the information in 
an execution section 190 (discussed below) of the . order 
entry window 160 for the current order. If the user 

25 selects the Delete Execution Button 144, the current 

order (as displayed in the execution section 190) will be 
deleted. 

Turning now to Fig. 6, there is illustrated a 
typical window used to enter orders that is displayed on 

30 the screen of the user workstation 4 by the order 

management process 100. The window is an order entry 
window 160 used by an investor to enter, for example, a 
buy order for a stock, bond or option or a sell order for 
a stock, bond or option. 

35 The order entry window 160 allows the user to 

enter and modify information for an order. For example, 
if the user wishes to create a new order, the user will 
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select the Write New Order Button 132 from the order 
management toolbar 130 and the order entry window 160 
will then be displayed at the user workstation 4 to allow 
the user to enter the. new order. Each order entry window 
5 160 represents one order and contains information about 
that order. In the representative embodiment, the 
background color of the order entry window for a buy 
order will be green, while the background color for a 
sell order is red. This allows the user to quickly 
10 identify the type of order .displayed on the screen of the 
user workstation 4. The order management process 100 
allows a user to open multiple order entry windows 160. 
The order entry window 160 for the current order is 
highlighted. 

15 The order entry window 160 allows the user to 

edit or write an order. The order entry window 160 
comprises several boxes. A type box 162 allows the user 
to enter the type of order. Typical types include 
"stock", "bond", "option" and "other." As shown in Fig. 

20 6, the type box 162 shows the letters "ST" representing 
"stock". A side box 164 allows the user to enter the 
side for the order. Typical sides are "buy," "cover 
short," "sell" and "sell short." 

A quantity box 166 allows the. user to enter the 

25 total order quantity. A symbol box 168 allows the user 
to enter the security symbol or other identifying code 
for the stock, bond, option, etc. that the user wishes to 
trade. For example, as shown in Fig. 6, the symbol 
entered in the symbol box 168 is "IBM," representing 

30 shares, in IBM Corporation. 

A price box 170 and fraction box 172 together 
allow the user to enter the price for the trade. 
(Typically, for stocks, the price includes a whole number 
portion and a fraction.) The order entry window 160 

35 allows the user to enter the price as either a decimal or 
a whole number with a fraction. Additionally, the order 
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entry window 160 allows the user to enter "Mkt" (or just 
n M") in the price box 170 to price an order at market. 

A peg box 174 allows the user to select the 
type of pegging. Typical types of pegging include 
5 pegging to market, to last price, to primary market, to . - 
best, to middle and to opening. Further, the user can 
peg a price of an order, but if an external event occurs, 
then have the system of the present invention change the 
price of the order. If the exchange does not permit a 

10 particular type of peg, the control engine 2 of the 

present invention, where possible, modifies the order to 
one accepted by the exchange without loosing the 
functionality desired by the. user. For example, Instinet 
allows a peg to a mid price, but CSE does not. If the 

15 user wishes to peg to mid price on CSE, the control 

engine 2 can receive as input the current bid and ask ' 
price on CSE, and submit an order which is in effect 
pegged to the mid price. If bid or ask price changes, 
the control engine then submits a price change 

20 instruction to CSE (or alternatively, may cancel the 

unexecuted order and resubmit the order at a new price.) 

A solicit box 176 allows the user to identify 
whether the order was solicited or not. An open box 178 
and a put box 180 are relevant for option trades only. • 

25 If the user selects the open box 178, this denotes, an 

opening option trade. If the open box 178 is unchecked, 
then it is a closing option trade. If the put box -180 is 
selected, then the trade is a put, otherwise it is a 
call . 

30 A customer code box 180 allows the user the 

option of entering a customer code for the order. The- 
customer code entered in the customer code box 182 must 
match a valid customer code in the CustMast table. An 
account box 184 allows the user to enter an account 

35 number. 
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A gun box 186 allows the user to enter a gun 
code to utilize the gun feature. The gun feature is 
discussed in more detail below with reference to Pig. 14. 

A flip box 18 8 can be selected by the user to 
5 designate a flip. If the user, selects the flip box, the 
trade is marked as a flip trade. As is known in the 
securities industry, a flip trade designates that the 
order is to be cleared by a broker other than the broker 
that executed the trade. In the representative 

10 embodiment of the present invention, after the order has 
been executed, all orders will be automatically sent for 
clearing to a designated clearing entity. The designated 
clearing entity will have a computer terminal that will 
be coupled to the control engine 2 of the present 

15 invention. (The designated clearing entity usually 
receives a commission for clearing the execution.) 
However, the user may require that, for a particular 
trade, the clearing of the trade be completed by another 
broker. To comply with securities laws and regulations, 

20 a flip contract must be in existence between the two 

brokers (i.e., the broker that executes the trade and the 
broker to whom the clearing of the trade is to be 
flipped) . In the representative embodiment of the 
present invention, if the flip box 188 is marked by the 

25 user, the; control engine 2 will generate, after the order 
has been executed, the appropriate flip documentation to 
be sent to the new clearing broker. Moreover, the 
control engine 2 will send a computer message to the 
previously designated clearing entity informing that 

3 0 broker that the trade has been flipped and not to clear 
that particular trade. Further details concerning the 
communication between the control engine 2 and the system 
designated clearing entity are discussed in more detail 
below, 

35 Alternatively, certain accounts available to 

the user are designated as flip accounts. If the user 
selects as the account code a flip account code, then the 
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10 



order is automatically designated as a flip, a clearing 
entity is associated with each flip account code. Thus, 
the user can flip the execution of one trade to Broker A 
and another to Broker B by designating the appropriate 
flip account codes for each trade. 

A commission box 189 displays the commission 
rate for the transaction. Typically, where the user is 
charged a commission for each trade executed. Usually, 
the commission charge is in cents per share. The 
information that is displayed to the user in. the 
commission box 189 is automatically obtained from the 
CustMast table. Where the user is a broker, the system 
of the present invention allows the broker to modify the 
commission rate by entering a new rate in the commission 
15 box 189. 

The execution section 190 of the order entry 
window 160 is completed by the control engine 2 after the 
order displayed in the order entry window 160 has been 
executed. The information placed in the execution 
section 190 includes the "date and time of. the execution, 
the executed quantity, the executed price, the MMXD 
(Market Marker ID) on the other side of the trade, an 
exchange flag and an exchange trade reference number. If 
it was a multiple executed order, the user can scroll 
25 through the execution details for. the order. 

Turning now to Fig. 7 there is illustrated a 
detailed order entry window isoa. The detail order entry 
window 160a is divided into five sections, namely, an 
order window 161 (as described above in relation to the 
30 order entry window 160)., the execution section 190 ; an 
order options window 191, a customer discretion box 198 
and a broker discretion box 199. (In fact, the detailed 
order entry window 160a is merely a different display 
arrangement for the order entry window 160 - the order 
35 entry window 160 simply -hides" sections of the detailed 
order entry window 160a.) The detailed order entry 
window 160a is displayed when the user selects a maximize 
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option from a pull -down menu on the order management 
toolbar 130. 

The order options window 191 comprises three 
boxes, namely a condition box 192, a type box 194 and a 
5 "good. until" box 196. The condition box 192 allows the 
user to enter conditions for the order. Typical 
conditions include "day," "good until canceled," "good 
until,..," "opening only, " "market on close," "limit oh 
close," "immediate," and "fill or kill." If the user 

10 selects "good until," the "good until" box 196 allows the 
user to enter a date, time or number of minutes for which 
the order remains good. The type box 194. allows the user 
to specify the type of "good until" condition, i.e., 
whether the order is good until a time or good until a 

15 date. If the user selects "date" and enters a date in 
the "good until" box 196, the order will expire on that 
date. If a user selects "time," and enters a time in the 
"good until- box 196, the order will expire at that time 
on the same day. If the user selects "number of 

20 minutes," and enters a number in the "good until" box 

196, the order will expire after that number of minutes. 
For example, if the user selects "57," the order will 
expire 57 minutes from the current time. 

The customer discretion box 19 8 is a notepad 

25 for recording customer notes. The broker discretion box 
199 is notepad for recording broker notes. 

After the user has entered an order using 
either the order entry window 160 or the detailed order 
entry window 160a, the user may send the order for 

30 execution to the stock exchange or automated trading 
system designated in the CTCI routing box 156 of the 
order mana gement toolbar 130, or alternatively, the user 
may decide to "save" the order so that it can be sent for 
execution at a later time, for example, by "loading" the 
.35 order into a gun, as discussed below. The details about 
each order entered by the user and the. status of each 
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order is then displayed in a book-view window 250, 
discussed in detail below with reference to Fig. 10. 

Turning now to Fig. 8 there is illustrated in 
block diagram form the functions performed by the order 
5 management process 100 of Fig. 4. As stated above, the 
order management process 100 is executed on the user 
workstation 4 and allows the user to enter, modify or 
cancel orders by way of the order entry window 160, the 
detailed order entry window 160a and the order management 

10 toolbar 130 described above. 

A log-on function 102 obtains from the user a 
user identification code and a password. The log -on 
function 102 displays on the screen of the user 
workstation a log-on box (not shown) so that this 

15 information can be obtained from the user. .If the 

correct password. is entered, the log-on function allows 
the user access to the system of the present invention. 
The log on function 102 also determines a user group for 
the user. The user group is a parameter used by the 

20 control engine 2 to determine what information in the 
database 6 the user can have access to and which orders 
in the system the user may see and act on. 

A help icon function 103 turns on the context 
sensitive help and controls the display of help 

25 information on the screen. The help icon function 103 
will be activated when the user selects the context 
sensitive help button 146. 

An exit icon function 104 terminates the order 
management process 100. The exit icon function 104 is 

30 executed when the user selects the exit button 148. 

A windows menus function 105 controls the 
operation of the pull -down menus on the order management 
toolbar 13 0. The order management toolbar in the 
representative embodiment allows the user to select five 

35 pull-down menus, namely, a file menu (to allow the user 
to exit) , a window menu (to control the display of the 
order entry window 160) , an actions menu, a history menu 
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and a help menu. The actions menu has commands, (that 
can be used as alternatives to the buttons described 
above) such as to save, close, undo orders. The actions 
menu also includes a shares command that, when selected 
5 by the user, displays a quick quantity change window (not 
shown) to allow the user to quickly change the quantity 
of an order using a mouse device. The actions menu 
further includes an allocate trades command that opens a 
window to allow mass allocation of account numbers to 
10 trades without having to know the tag number for the 
order. 

The history menu, when selected, opens a window 
showing the orders that were entered or modified during 
the current session. 

15 A DDE function 106 coordinates the flow of 

information between the order management process 100 and 
the other processes shown on Fig. 4. For example, the 
DDE function accepts DDE messages from the book-view 
process 200 to open an order entry window 160 or 160a for 

20 modification of an order. The DDE function also accepts 
messages to release an order, to cancel an order and to 
suspend an order. The cancel, suspend, and release 
messages that are received by the DDE function 106 cause 
the order management process 100 J to format appropriate • 

25 queue rows, as discussed in detail below. 

A new order function 107 opens a new order 
entry window 160 or 160a and allows the user to enter 
routing information on the order management toolbar 130. 
A save order function 108 stores changes to an existing 

30 order in the database 6 and then formats a queue row 

for updating. The save order function 108 is executed 
when the user selects the File Changes Button 134 on the 
order management toolbar 130. 

A hide order function 109 performs the same 

35 function, as the save order function 108, but in addition, 
a DDE message is sent to the book-view process 200 
instructing it not to display that order. The "hide order 
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function 109 is activated when the user selects the File 
Changes & Hide Button 136 from the order management 
toolbar 130. 

A "don't save" function no closes the current 
5 order entry window 160 or 160a but does not modify any 
tables of the database 6. The "don't save" function 110 
is activated when the user selects the Close Current 
Order Button 13 8 from the order management toolbar 13 0. 

An undo function 111 discards any changes made 
10 to the current order window 160 or 160a and resets the 

order entry window 160 or 160a. The undo function 111 is 
activated when the user selects the Undo Button 140 from 
the order management toolbar 13 0. 

A Post -Execution order entry function 112 will 
15 cause the order entry window 160 to be displayed and will 
allow the user to enter information about a trader. This 
feature is available, for example, to allow the user to 
enter information about a manual execution done away from 
the system. 

20 An add execution function 113 allows a user to 

manually enter execution information in the execution 
■ section 190 of the order entry window 160, for example, 
for a manual exchange. 

A delete execution function 114 deletes 

25 selected order execution information. For example, if an 
exchange sends an execution report by mistake, and then 
telephones the user to inform the user of this mistake 
(i.e., a "busted trade"), the user can delete execution 
details from the execution section 190. 

30 A quick destination function 115 will route the 

order entered on the order entry window 160 to an 
exchange or automated trading system. The designation 
function 115 will write appropriate queue rows for the 
order, as discussed in. detail below. The quick 

35 destination function 115 exists for each Quick Route 
Order Button 150 on the order management toolbar 130. 
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The. exchange list function 116 formats and 
writes appropriate queue rows in relation to the exchange 
or automated trading systems selected by the user using 
the CTCI routing box 156 of the order management toolbar 
5 130. The exchange list function 116 also has the 
capability for displaying all. valid destinations or 
routing on the order entry window 160. 

The exchange list function 116 and the quick 
designation function are executed when the user enters or 

10 selects the appropriate information at the order 
management toolbar 130. 

A manual routing function 117 will accept a 
destination not recognized by the exchange list function. 

A prices list function 116, when executed, will 

15 show prices surrounding the offering price for the 

security selected by the user and entered in the symbol 
box 168. The offering price will be displayed in the 
price box 170. The prices list function 119 will also 
display the prices surrounding the offering price in the 

20- price box 170 for easy mouse or keyboard selection by the 
user. The prices list function is execution whenever an 
order is modified, for example', when the File Changes 
Button 13 4 is selected. 

An accounts list function 119 will cause the 

25 display of a list -of valid accounts. The accounts list 
function 119 also allows the user to select an account 
and then assign that account to an order in the order 
entry window 160. The accounts list function 119, is 
executed whenever the user selects the customer account 

30 code box 154. 

The" DDE Manager process 500 coordinates 
communications between the user workstation 4 and other 
application programs, such as proprietary expert systems, 
neural networks and computerized models. Using the DDE 

35 interface protocol, the DDE Manager process 500 can 
accept orders from application programs and supply 
information to applications programs that are DDE 
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compatible. Accordingly, many different modules can be 
incorporated into the present invention. 

In the representative embodiment, the present 
invention can include an expert system 9 coupled to the 
5 user workstation 4. The expert system 9, interfacing 
with the DDE Manager process 500, can input orders, and 
receive execution information. Typically, the expert 
system 9 operates on a dedicated computer processor, but 
alternatively, can be executed and operated by the user 

10 workstation 4. In this embodiment, the expert system 9 
is a portfolio expert system. The portfolio expert 
. system (PES) of -the present invention first examines a 
nominal portfolio of stocks. The PES assembles a basket 
of stocks from this portfolio as follows. The PES 

15 determines the relative value of each stock in the 

portfolio, relative to the other stocks in the portfolio, 
and ranks the stocks in order of their relative value. 
The PES then constructs the. basket by selecting a 
predetermined number of stocks from each end of the 

20 relative order, for example, the top ten stocks by value 
and bottom ten stocks by value. The PES then sends 
instructions via DDE comprising buy orders for the bottom 
ten stocks and sell short orders of the top ten stocks. 
The quantity of each stock traded in the transaction is 

25 determined by its position in the relative order. The 

PES continuously examines market information and re -ranks 
the stocks. If a stock changes its relative ranking, the 
PES can issue the appropriate command, via DDE, to "re- 
balance" the basket. The PES receives real-time 

30 execution information and other information and feedback 
via the DDE interface. Accordingly the PES feature of 
the present invention allows an investor to micro -manage 
a basket of stocks and to execute trades swiftly if 
market conditions change. 

35 The. user workstation 4 of the present invention 

can be coupled to numerous and different expert systems. 
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The spreadsheet process 600 is simply a DDE 
compatible spreadsheet, such as, for example, Microsoft's 
Excel spreadsheet. Using this feature, the user can 
input information via a spreadsheet and "export" 
5 information, such as execution information to the 

spreadsheet. The information can be input and exported 
in real-time. 

Turning now to Fig. 9, there is illustrated a 
Fast Order Entry ("FOE") Window 350. The FOE Window 350 

10 is an add-on graphical user interface that complements 

the Order Entry Window 160 of Fig. 6. The FOE Window 350. 
is controlled by and interfaces with an add-on FOE 
function of the Order Management Process 100. The FOE 
function is executed by the processor of the user 

15 workstation .4. 

The FOE Window 350 can be displayed on the 
screen of the user workstation 4 and information can be 
entered, as described above, using a mouse device. 
Alternatively, the FOE Window can be displayed on a touch 

20 screen coupled to the user workstation 4 and information 
, can be entered by the user using the touch screen. The 
FOE Window 350 can also be run on another PC coupled to . 
the workstation 4. 

The FOE Window 350 is designed for investors 

25 who need to immediately respond to trading opportunities. 
Using the FOE Window 350, a trade can be entered in- 
seconds with as little as only four commands. 

• The FOE Window 350 comprises an order type 
command line 362 that has four buttons, one button for 

30 each order type, namely, buy, sell, cover short and sell 
short. The FOE Window 350 also comprises a symbol 
section 3 64. The symbol section 364 comprises a number 
of preset ticker buttons, such as those labeled AMD, IBM 
and GLX. Each preset ticker button represents a security 

35 that can be traded. The buttons in the symbol section 
364 are preset by the user at an earlier time so that 
they represent securities that the user is actively 
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• interested in. Other preset symbols can be hidden, and 
displayed only when the user selects the down arrow 
button 3 65. 

Also on the FOE Window 350 is a routing line 
5 368 that comprises preselected routing buttons 368. Each 
preselected routing button represents one source of 
liquidity where the security may be traded, such as, for 
example, a specific stock exchange or a booth 
workstation. 

10 There are at least two ways to operate the FOE 

Window 350. First, the user sets up in advance a 
portfolio of ticker symbols (each ticker symbol 
representing a stock) . The user can allocate an initial 
share size and price to each ticker symbol. Each ticker 

15 symbol will be displayed on the FOE Window 350 in the 
symbol section 3 64. When a trading opportunity exists, 
the user begins by selecting either a buy, cover short, 
sell or sell short by activating the appropriate button 
in the order type command line 362. (On a touch screen, 

20 the user simply touches the appropriate button. With a 
mouse, the user points at the appropriate button and 
clicks.) A menu bar 352 on the FOE Window 350 displays 
the selection (at 353) and the ticker symbols in the 
symbol section 3 64 are highlighted.. The user then 

25 selects the appropriate ticker button (far example, the 
button labeled "IBM") . On the menu bar 352, the FOE 
Window 3 50 displays the preselected share amount and 
preselected price 357 (for example, 2,000 IBM shares at 
50). In an alternative embodiment, the price displayed 

30 on the menu bar 352 is a function of current market 

information (such as, for example, the bid price for a 
sell order or the offer price for a buy order) obtained 
from the on-line source of price and/or market 
information 16. To change the price, the user may select 

35 a price arrow 358 on the menu bar 352 to move the price 
up or down, or the user may select one of a number of 
preselected pricing alternatives from a group of 
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preselected pricing alternative buttons 362 (i.e., 
market -on- close, market, last, etc.). To change the 
share amount, the user may select an amount arrow 3 54 or 
356 to change the order in lots of 100 (i.e. arrow 354) 
5 or in lots of 1,000 (i._e., arrow 356). Next the trader 
selects one of the preselected routing buttons 368. The 
route selected is displayed on an enter order button 370 
, on the FOE Window 350. The user may then either clear 
the order, (i.e, do nothing) by selecting a clear order 

10 button 372 or send the order for immediate execution by 
selecting the enter order button 370. 

Thus, an order can be entered and sent for 
execution with only four commands; namely, (i) selecting 
an order type from the order type command line 362, (ii) 

15 selecting a ticker symbol from the symbol section 364, 
• (iii) selecting a routing for th6 order from one of the 
preselected routing buttons 368, and (iv) entering the 
order by selecting the enter order button 370. With few 
. additional commands, the user can modify the preselected 

20 amount and price of the order. 

Alternatively, the user can select a quick 
entry button 366 on the FOE Window 350. When the quick 
entry button 3 66 is selected, the user is prompted to 
enter, using a keyboard, the share amount, ticker symbol 

25 and price. This information, when entered, is displayed 
on the menu bar 352. The user then selects the routing 
for the order from one of the preselected routing buttons 
368, and enters the order by selecting the enter order 
button 370. 

30 When an order is entered using the FOE Window 

350, it is processed in a similar fashion by the control 
engine 2 as orders that are entered using the order entry 
window 160 or detailed order window 160a. 

Once an order has been entered by the user, the 

35 system of the present invention allows the user to 

monitor the status of each order in real-time. The book- 
view process 200 operates on the user workstation 4 and 
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interacts with the database 6 of the control engine 2. A 
Book-View ( n B V n ) window 250, as shown in Fig. 10, is 
controlled by and interfaces with the book -view process 
200 of the Order Management Process 100. The BV window 
5 250 shows status and execution information, updated in 

real- time, about each order entered using the order entry 
mechanisms of the present invention. The BV window 250 
comprises three parts, namely, a status window 210, an 
execution window 260 and a BV toolbar 280. 

10 The status window 210 displays the status of 

all orders entered via the user workstation 4. As stated 
above, those orders may have been entered, for example, 
using the order entry window 160, the detailed order 
entry window. 160a, the FOE Window 350 or using the DDE 

15 manager process 500. (As discussed below, orders may 

also be entered automatically using an order alert system 
or a gun. These orders and their status are also 
displayed in the status window 210.) Where many user 
workstations are coupled over a LAN 20, as shown in Fig. 

20. 2 (e.g. workstations 4D-4F) , one workstation may be 
dedicated to performing book -view functions. 
Accordingly, that dedicated workstation may display the 
status of all orders entered by all users at the 
workstations coupled to the LAN 20. Alternatively, each 

25 user workstation 4. on the LAN 20 may have the capability, 
of viewing, using its BV window 250, all orders entered 
on all user workstations 4 on the LAN 20. 

The status window 210 displays the status of 
each order. The status window 210 is divided into a 

30 number of sections. In the representative embodiment, 

the sections of the status window 210 are displayed in a 
column format. In the representative embodiment, the 
different sections of the status window 210 are as 
follows: a side column 212, a quantity column 214, a 
.35 symbol column 216, a price column 218, an execution 

quantity column 220, a leaves column 222, a tag column 
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224, -an exchange column 226, a status column 228 and a 
customer column 230, 

In the representative embodiment, each order is 
displayed in one row of the status window 210. The side 
5 column 212 lists whether the order is a buy. order, a sell 
order, a cover short order or a sell short order. Buy 
and cover short orders are displayed in green and sell 
and sell short orders are displayed in red. The quantity 
column 214 lists the total quantity of the order, for 
10 example, 95,000 shares. The symbol column 216 lists the 
ticker symbol or other identifying code for the order. 
The price column 218 lists the price the user set for the 
order. 

The execution quantity column 220 lists the 

15 total quantity of the order that has been executed so 

far. The leaves column 222 shows how much of the order 
is yet to be executed. For example, if the order is to 
buy 95,000 IBM shares, and so far 50,000 IBM shares have 
been purchased (i.e, the order has been partially 

20 executed), the execution quantity column will show 50,000 
and the leaves column will show 45,000. (Thus, the 
leaves quantity is the order quantity minus the execution 
quantity.) These columns are updated in real-time as 
information about the order becomes available, as 

25 explained' in detail below. 

The tag column 224 displays a tag number which 
is an internal reference number to uniquely identify the 
order. The exchange column 226 lists the exchange or 
system to which the order has been routed. The status 

30 column 228 lists the status of the order. The following 
is a list of the possible status for an order: held 
order ( the order has been held by the user, i.e., 
information about the order has been entered in the 
system of the present invention but the order has not yet 

35, been sent for execution) ; new order (the order has been 
sent /for execution but it has not yet been confirmed as 
received by, e.g., the exchange); active order (the order 
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has been sent for execution and is. active); suspended 
order (the order has been sent for execution but has been 
suspended by the user of the system of the present 
invention); canceled (the order was sent for execution 
5 but has been canceled) ; and executed (the order has been 
completely executed - such an order is now called an 
executed trade) . 

Suspending an order is not an action typically 
allowed by an exchange. When the user suspends an order, 

10 the system of the present invention will in fact send a 
message to the relevant exchange canceling the order, but 
will keep the information about the order in the system 
(for example, in the database 6) so that the user may 
release the order (or modify the order) at a later time. 

15 Thus, if the user cancels a suspended order, nothing is 
. sent via a CTCI to any exchange.' 

The status indicators in the status column .228 
are displayed in different colors, e.g., active is blue, 
canceled is red, suspended is yellow, executed is green, 

20 to enable the user to easily determine the status of an ! 
order. Accordingly, the status column 228 provides real- 
time information to the user concerning the status of 
each order the user has entered into the system of the 
present invention. 

25 , The customer column 230 lists an alphanumeric 

code representing the account for the order. 

A gun column (not shown) is to identify any 
order that is subject to a gun, as explained in detail 
below. An CTCI message column (not shown) displays an 

30 image of the last CTCI message received from an 
electronic 'exchange related to the-^rder. 

The display of the columns in the status window 
210 can be modified by the user. For example, the user 
may hide columns from the status window 210. 

35 " The BV window 250, as stated above, also 

comprises an execution window 260. The execution window. 
260 lists each execution (or trade). that has taken place. 



S0002907 



WO 93/06918 



PCT/US94/09398 



10 



55 

The execution window 260 is updated in real-time whenever 
the control engine 2 receives an execution report from an 
exchange or automated trading system. It is noted that 
if an order is execute in parts, as each part is executed 
information concerning the partial execution is displayed 
in the execution window 260. Accordingly, information 
about an executed trade may appear in the execution 
window 260 even though the status of the order in the 
status window 210 may be listed as active. 

The arrangement of the display of the execution 
window 260 and the status window 210, and the number of 
rows and columns of each window, can be controlled by the 
user. Typically, the execution window 260 is displayed 
on the user workstation 4 at the same time as the status 
15 window is displayed, as shown in Fig. 10. However, the 
execution window 260 can also be displayed alone, with' 
the status window hidden from view, as shown in Fig. n. 

The execution window 260 (as shown in Fig. 11)' 
also comprises a number of columns. A side column 262 
20 lists whether the order is a buy order, a sell order, a 
cover short order or a sell short order. Buy and cover 
short orders are displayed in green and sell and sell 
short orders are displayed in red. A. quantity column 264 
lists the executed quantity of the order. A symbol 
25 column 266 lists the ticker symbol or other identifying 
code for the executed order. A price column 268 lists 
the executed price of the order. A tag column 270 . 
. displays the tag number to identify the order. An 
exchange column 272 lists the exchange or other 
30 destination to which the order was sent. A time column 
274 lists the. time of trade execution in the exchange's 
time zone. A contra column 276 lists the MMID on the 
other side of the trade. A flags column 278 lists the 
exchanges flags. A reference column 279 lists the 
35 exchange trade reference number. 

The BV toolbar 280 is shown in further detail 
in Fig. 12. The BV toolbar 280 comprises several 
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buttons, a CTCI status indicator 294 and an information 
box 292, Typically, the BV toolbar is continuously 
displayed at the top of the BV window 250.. 

The buttons on the BV toolbar 280 include a 
tools button 282, a context sensitive help button 284, a 
cancel button 286, a suspend button 288, a release button 
290, a modify button 283, a hide button 285, a show/hide 
hidden orders & trades button 287 and a scroll locked 
button 289 . 

The tools button 282, when selected by the 
user, causes a utility window (not shown) to be displayed 
on the user workstation 4 . The utility window allows the 
user to customize the BV window 250. Using the utility 
window, the user can select orders for guns, and also 
15 select (using various parameters, for example, all orders 
involving IBM stocks) . orders to be displayed on the BV 
window 250. Using the utility window, the user, if 
connected to a LAN 20, can also view orders of other 
users in the user group. 
20 The context sensitive help button 284, when 

selected by the user, will display help information as. 
discussed above. 

The cancel button 286 allows a user to cancel 
an order. In the representative embodiment, an order is 
25 canceled by dragging the order from the status window 210 
and "dropping" it on the cancel button 286. 
(Alternatively,- an order can be selected to be canceled 
by clicking on the order. The order will be displayed 
with a rectangle around it and the tag number of the 
30 selected order is displayed in a selected order tag field 
296 of the BV toolbar 280". " The user cancels this order 
by then selecting the cancel button 286.) An order that 
has been canceled or executed cannot be canceled. (If 
the user cancels less than 100% of the non- executed 
35 quantity of a new order not yet confirmed, . an active 
order or a suspended order, only the quantity of the 
order will be reduced.) The suspend button 288 allows a 

S0002909 



WO 95/06918 



PCT/US94/09398 



57 



user -to suspend an order. In the representative 
embodiment, an order is suspended by dragging the order 
from the status window 210 and "dropping* it on the 
suspend button 288. An order that has been canceled, 
5 suspended or executed cannot be suspended. (If the user 
suspends less than 100 V of the non- executed quantity of 
an order, its quantity will be reduced, if the user 
suspends less than 100% of the quantity of an order, a 
held order is created that contains the balance of that 
10 quantity.) The release button 290 allows a user to 
release (i.e. send for execution) a suspended or held 
order. (If the user releases less than 100% of the 
quantity of an order with a held status, a new held order 
is created that contains the balance of the order 
15 quantity. If the user releases less than 100% of the 
non-executed quantity of an order, its quantity is 
reduced and the order is released.) In the 
representative embodiment, an order is released by 
dragging the order from the status window 210 and 
20 "dropping- it on the release button 290. The modify 
button 283 allows a user to modify an order. ' In the 
representative embodiment, an order is modified by 
dragging the order from the status window 210 and 
"dropping" it on the modify button 290. When this 
25 occurs, the order management process 100 is called and 

the order entry window 160 or 160a for the selected order 
is displayed so that the order can be modified. 

The hide button 28S allows the user to hide 
from view a selected order or executed trade. Hiding an 
order or executed trade does not affect the status of the 
order. The show/hide hidden orders & trades button 287, 
when selected, will show all hidden orders and executed 
trades. When selected for a second time, those orders 
and executed trades marked to be hidden will be hidden. 
35 The scroll locked button 289 will lock the 

scrolling feature of the BV window 250. When the 
scrolling feature is on (which is the default setting) , 
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all .orders and executed trades are continuously updated 
and scroll through the window. When the scroll locked 
button is selected, the screen locks on the currently 
displayed orders and trades. 
5 The information box 292 displays current 

information and is continuously updated. For example, 
the information box can be programmed to display the 
current time and the current Dow Jones Index. 

The CTCI status indicator 294, in the 

10 representative embodiment displayed as traffic light 

icon, gives a visual indication (a green light) that all 
CTCI interfaces between the control engine 2 and the 
various exchanges and automated trading systems (e.g., 8 
to. 12) are up and working. If all CTCI interfaces are 

15 not working (i.e, at least one CTCI is down), a red light 
will be displayed. A sound can be produced, for example, 
a beep every ten seconds, if a CTCI interface goes down 
until the user acknowledges that fact. 

The elected order tag field 296 lists the tag 

20 number of any order that has been selected for further 
action, e.g., an order to be canceled or modified. 

The BV Window also has a number of pull -down 
menus 299, including those that provide file functions 
(e.g., printer set-up, alternative access to the 

25 utilities window, exit command), sort functions 

(explained below) , actions functions (e.g., cancel order, 
suspend order, release order, modify order, hide 
execution window 260, average pricing command, preopening 
command) , CTCI functions (to display the status of all 

30 CTCI's coupled to the control engine 2) , print functions 
(to print interim and end of day reports) and help 
functions . The user can select sort commands . in the 
"sort" pull -down menu to .sort the entries (i.e., the 
orders and executed trades) that are to be displayed in 

35 the BV window 250. For example, the user may sort the 

executed trades, and unexecuted orders by ticker symbol or 
by quantity. In the representative embodiment, a sort 
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window (not shown) allows the user to create and catalog 
customized sort orders - these customized sort orders are 
thereafter displayed in the "sort" pull -down menu for 
selection. 

An average pricing command in the " action ■ 
pull -down menu opens an average price window (not shown) 
where the user can group trades for average pricing. For 
any order, there can be multiple executions on the order. 
For example, if the user sends a sell order for 5,000 
shares, those shares actually may be sold in five 
"batches- of 1,000 shares each, with each trade for each 
batch at a different price. Using the average price 
command, the user can group related trades to determine 
the average price for the complete order. (As an 
15 alternative feature, a process can automatically group 
all the related trades at the end of the day and 
automatically determine an average price for those 
trades . ) 

The preopening command of the "action" pull- 
down menu displays the current pre -opening indications. 

Turning now to Fig. 13, there is illustrated in 
block diagram form the functions performed by the book- 
view process 200. 

A log-on function 2002 displays a log-on window 
25 (not shown) to allow the user to log- on and enter a 

password. The log-on function 2002 determines the user 
group for the user and determines what information the 
user may have access to in the database 6. 

A delete icon function 2006 is executed when 
30 the user selects the cancel , button 286. The delete icon 
function 2ti06 sends a command to the DDE function 106 of 
the order management process 100 to cancel the selected 
order. The command is sent via DDE. The delete icon 
function 2006 also updates the status window -210. 
35 A suspend icon function 2007 is executed when 

the user selects the suspend button 288. The suspend 
icon function 2007 sends a command to the DDE function 
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106 of the order management process 100 to suspend the 
selected order. The command is sent via DDE. The delete 
icon function 2006 also updates the status window 210. 

A release icon function 2008 is executed when 
5 the user selects the release button 290. The release 
icon function 2008 sends a command to the DDE function 
106 of the order management process 100 to release the 
selected order. The command is sent via DDE. The 
release icon function 2008 also updates the status window 
10 210. 

A modify icon function 2009 is executed when 
the user selects the modify button 283. The modify icon 
function 2009 sends a command to the DDE function 106 of 
the order management process 100 to open the order entry 

15 window 160 or 160a for the selected order. The command 
is sent via DDE. 

A hide icon function 2010 is executed when the 
user selects the hide button 285. ' The hide icon function 
2010 marks the selected order or executed trade that is 

20 to be hidden. (Each user workstation 4 keeps a list of 
those orders or trades that are to be hidden.) When the 
show/hide hidden orders & trades button 287 is set to 
hide , the marked hidden orders and trades are not 
displayed. A show/hide icon function 2011 toggles the 

25 hide/show selection when the user selects the show/hide 
hidden orders & trades button 287. 

A control icon function 2003, executed when the 
user selects the tools button 282, causes the utility 
window to be displayed. A help icon function 2004 , 

30 executed when the user selects the help button 284, turns 
on the context sensitive help feature. An exit icon 
function 2005, executed when the user selects the exit 
command from the "file" pull-down menu 299, causes the 
book- view process 200 to terminate. 

35 A CTCI status function 2012 controls the 

display of the CTCI status indicator 294. This 
information is obtained from the Code table. (The 
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control engine 2 updates the code table whenever there is 
a change in the status of a CTCI.) 

A dow box function 2013 controls, the display in 
the information box 292. The dow box function' 2013 
5 continuously receives and monitors information from the 
: online source of price and/or market information 16 and 
updates the information box 292 accordingly. 

A windows menus function 2014 controls the 
operation of the puli-down menus 299. This function 
10 controls the display of a number of additional window 
2016-2018, discussed below. These windows can be 
selected for display by the user. 

A trade window 2015 displays the current trade 
executions in the execution window 260 and the status 
15 window 210. 

An order window 2016 displays the current order 
information in the status window 210. 

A top-of-book window 2017 displays the best bid 
and best price on a specified exchange or electronic 
20 trading system. " 

A pre -opening window 2018, in the 
representative embodiment, shows the pre -opening 
information obtained from the Cincinnati Stock Exchange. 

Turning now to Fig. 14, there is illustrated a 
25 list window 450. The list window 450 is controlled by 
and interfaces with the list process 400. The list 
process 400 is executed by the processor of the user 
workstation 4. The list process 400 controls the user 
interface that processes and executes guns. Guns are 
30 predefined groups of orders that can be released 

("fired"), suspended or canceled as a group. r<N 

The list window $%) comprises ah orders window 
410. The orders window 410 is similar in structure and 
contents to the status window 210 discussed above. 
35 Functions similar to those explained above, such as 

suspending an order, releasing an order and deleting an 
order, can also be carried out from the list window 410. 
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However, these functions are carried out not on a single 
order, but on a group of orders. 

The user can nominate all or part of a gun 
using dollar or percentage limiters. Accordingly, the 
5 list window comprises a percentage box 410 and . a dollar 
box 420.. The percentage box 410 allows the user to 
nominate a percentage from one to 100. That percentage 
is applied to order volumes for the nominated action. 
For example, if 50V of a gun is selected for release, 

10 only half the order volume will actually be released when 
the gun is fired. (The volume is rounded down to the 
next lower round lot as an odd- lot would be produced.) 
The dollar box 420 allows the user to enter a dollar 
limit for the nominated action. For example, if a 

15 $500,000 dollar limit is entered, orders will be released 
when the gun is fired until a maximum order value of 
$500,000 is reached. Alternatively, a partial amount of 
each order listed in the gun is executed, the total value 
of all partial amounts being equal to $500,000. 

20 The delete, suspend and release functions for a 

gun all operate in a similar fashion, except that the 
functions queue different CTCI actions. (Queuing is 
explained in detail below.) 

To call up a gun, the user selects the tools 

25 button 440, causing a utility window (not shown) to be 

displayed. Using the utility window, the user can select 
those orders that are the subject of a particular gun. 
(The user can make an order the subject of a gun by 
entering a gun code in the gun box 186, for example, when 

30 entering or modifying the order.) Using the utility 
window, the user names the. gun and may specify the 
criteria for the orders that are the subject of that gun. 

Those orders that are the subject of a gun are 
listed on the orders window 460 with the name of the 

35 gun(s), where applicable, in a gun column 430. 

Using the actions buttons 470 to 474 on the 
list window's toolbar, the user selects the action for 
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each gun. If the user selects the release action, only 
held or suspended orders qualify for the gun. If the 
user selects the suspend action, only active orders 
qualify for the gun. 
5 To summarize the use of guns, the release 

operation will be taken as an example. First, the user 
selects the orders to be loaded into the gun These 
orders are displayed in the orders window 460. Orders 
can be loaded into the gun using the utility window. 

10 (The utility window is accessed in the representative 

embodiment by clicking on the tools button 440.) Second, 
the user has the option of nominating a certain 
percentage of orders using the percentage selector 410 or 
the total dollar amount to be released using the dollar 

15 selector 420. Third, the user selects the release button 
474 to fire the gun and to release the selected orders as 
a group. There may be one or more stocks loaded in a gun 
and there may be one or more loaded guns in the system. 
Each gun may be fired manually or. 

20 automatically. The gun can be fired manually as 
discussed above. 

If the gun is set to be fired automatically, 
. the condition on which the gun is to fire must be set by 
the user. For example, the condition may be that IBM 

25 shares drop below $50. The list process 400 continuously 
monitors the online source of price and/or market 
.information 16. When the select condition (s) is met, the 
gun is fired automatically without human intervention. 
For example, if the gun was loaded with sell orders for 

30 IBM shares, and set with a, $50,000 dollar limit, enough 
orders would be executed so that $50,000 worth of IBM 
shares would be sent by the control engine 2 to the 
designated exchange (s) to be sold. Alternatively, 
instead of firing the gun automatically, when the gun's 

35 condition becomes true, the. user is immediately notified 
(for example, by a visual indication or a sound), and 
given the option of firing the gun manually. 
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When a gun is fired, the information about each 
order is placed in the BV window 250 for display to and 
manipulation by the user. 

The following is an example of the flexibility 
5 of the gun feature of the present invention. If an 
investor has a portfolio of stocks,, and needs to raise 
$50 million by selling some stock, the investor can load 
a number of guns. One strategy may be to load a large 
number of sell orders into one gun, and enter $50 million 

10 in the dollar selector box 420. The stocks to be sold 
could be sold on various and mixed exchanges and via 
various and mixed electronic trading systems. The list 
process 500 of the present invention will, after 
examining real-time price information, such as that 

15 obtained from the on-line source of price information 16, 
issue enough sell orders so that $50 million worth of 
stock (at current prices) is offered for sale. 
Alternatively, the investor could load a gun including 
over $50 million worth of sell orders for execution. By 

20 examining the execution information, the investor can " 
determine when the $50 million limit is reached, call up 
the gun (for example, by selecting the tools button 440) , 
and suspend or cancel the unexecuted orders. 
Alternatively, the gun could be set to fire automatically 

25 to cancel the outstanding (i.e. , unexecuted) sell orders, 
when $50 million is raised. As a third alternative, the 
investor could load a number of guns with many sell 
orders for small amounts of stock, and set each gun to 
fire at successive times. Thus, the sell orders are 

30 paced, so that the market is not flooded with sell 

orders. As execution information is received real-time, 
the guns could be set to fire at varying rates. For 
example, if the $50 million has to be raised by 3 p.m., 
the guns could be set to examine the execution of these 

35 orders - if the orders are being executed quickly, the 
orders need not be sent out for execution so quickly; 
however, if the orders are taking time to execute so that 
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the goal may not be reached on time, the sell orders may 
be sent for execution at an earlier time. 

.Turning now to Fig. 15, there is illustrated an 
Order Alert ( "OA" ) Window 510. The OA Window 510 is an 
5 add-on graphical user interface that complements the BV 
window 250 of Fig. 10. The OA Window 350 is controlled 
by and interfaces with an OA f inaction. The OA function 
is executed by the processor of the user workstation 4. 
Together, the OA Window 510 and the OA function comprise 
10 an OA system. 

The OA system is designed for traders who need 
to monitor and trade large lists of securities based on 
specific market criteria. The OA system enables a trader 
to monitor and execute hundreds of market and limit 

15 orders simultaneously. 

To operate the OA system, the user enters a 
security into the OA system. In the representative 
embodiment of the present invention, the security is 
displayed on the OA Window 510 in a ticker column 520. 

20 Continuously updated information is automatically 

displayed in columns alongside the ticker symbol of the 
selected security. A bid column 522 displays the last 
bid for the selected security on a predetermined 
exchange. An offer column 524 displays the last offer 

25 for the select security of a predetermined exchange. A 
last column 526 and a volume column 530 displays last 
trade information concerning the selected security and a 
change column 52 8 shows the corresponding price change. 
This information is obtained by the OA system from the 

30 online source of price and/or market information 16. 

Additionally, or alternatively, the information can be 
obtained from the control engine. 2 and may include 
execution information. The current market value of the 
order is displayed in a market value column 544. 

35 The use * enters the price at which the user 

wishes to conduct the trade (which is displayed in a 
target column 53 6) and the number of shares the user 
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wishes to trade (which is displayed in a shares column 
534) . The user also enters a number of conditions. The 
trade will only be sent for execution when these 
conditions are met. In the representative embodiment, - 
5 the user may enter up to three conditions, but the system 
can be easily modified so that more conditions can be 
utilized. Thus, in the representative embodiment, when a 
user enters a security into the OA system, the user is 
prompted to enter one, and up to three, criteria which 

10 must be satisfied to effect an execution. 

For example, a user can enter an order to buy 
10,000 shares of IBM, to be sent for execution only if 
the price is greater than 55 1/8, and if the bid size is 
greater than 3,000 shares and if the total volume traded 

15 is greater than 200,000 shares. 

The status of each condition is displayed in 
three condition satisfies columns 53 8 to 542. In the 
representative embodiment, if a condition is satisfied, a 
green "Y" is placed in the respective condition column. 

20 In the representative embodiment, if a condition is not 
satisfied, a red "N" is placed in the respective 
condition column. The current market value of the order 
is displayed in' a market value column 544. When all • 
conditions are satisfied, the order highlighted 545 is 

25 automatically sent out for execution via the control 

engine 2. The status of the order is also displayed on 
the BV window 250, as discussed above. 

Orders that are entered at a user workstation 4 
and sent for execution are processed by the control 

30 engine 2. The control engine maintains at least one 

database 6 that stores information about all orders from 
all user workstations 4. Each order can be routed by the 
control engine 2 to an exchange or automated trading 
system (e.g., 8-10) or to the booth workstation 14 of the 

35 present invention. The control engine communicates with 
each exchange or automated trading system via a CTCI. 
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Typically, there is at least one CTCI at the control 
engine 2 for each exchange or automated trading system. 

At the control engine 2, and associated with 
each CTCI, is a message queue. In the representative 
5 embodiment, each message queue is stored in an internal 
memory array. Each message queue will store each order 
or command that is to be sent to the exchange or 
automated trading system associated with the message 
queue. Bach message queue is processed by a dedicated 
10 processor. For example, the message queue used to 

communicate with Instinet 10 is processed by the Instinet 
processor 46. The message queue used to communicate with 
the DOT system a is processed by the DOT Out processor 
52. Each dedicated processor executes its own CTCI 
15 routine. Alternatively, each message queue can be stored 
in the database 6. 

Turning now to Fig. 16, there is illustrated in 
flow chart form the steps performed by a typical CTCI 
routine, for example, the CTCI routine that communicates 
20 with the DOT system 8. In the representative embodiment, 
the CTCI routine is run from a batch file from the 
Microsoft DOS operating system of the processor 46 (step 
501). a DOS text file is maintained to log each message 
sent to and received from the exchange (step 502) . 

The CTCI routine connects to the exchange using 
the sign-on procedure specified by the exchange (step 
503) . 

The CTCI routine can be terminated, for 
example, by a systems administrator (step 503). In the 
representative embodiment , the CTCI routine is\erminated 
by pressing the ESC key on a keyboard associated with the 
dedicated processor. 

An unacknowledged message queue is maintained 
by the dedicated processor (e.g. 46) . All messages 
35 (e.g., orders) that are sent to an exchange are placed in 
the unacknowledged message queue along with the time the 
message was sent until the exchange acknowledges that it 
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has received the message. The CTCI routine checks the 
oldest message in the unacknowledged message queue (step 
505). If no response has been received to this message 
from the exchange within a predetermine time, the oldest 
5 message is deleted from the acknowledged message queue 
(step 506) and the database 6 is updated to show that no 
response was received from the exchange for this message 
(step 507) . (Thus, the user will be notified, for 
example, that a particular order was not received by the 

10 exchange. This notification will be displayed on the BV 
window 250 at the. user workstation 4.) 

Next, the CTCI routine will determine if the 
unacknowledged message queue is full (step 508) . A 
finite number of messages are allowed to remain 

15 unacknowl edged. If the queue is full, the CTCI routine 
will not send any further messages to the exchange and 
will only continue to look for - acknowledgements from the 
exchange relating to messages in the queue. 

New messages, prior to being sent to the 

20 exchange, are stored on a new message queue of the 

database 6 . (In the representative embodiment , messages 
are placed in the new message queue using an SQL command. ■ 
A new message queue exists for each CTCI.) The 
appropriate CTCI routine will examine the appropriate new 

25 message queue to determine if there are any new messages 
to be sent to the exchange (step 509). If the 
unacknowl edged message queue is not full and there is a 
new message to send, the CTCI routine will format the new 
message and transmit it to the exchange (step 510). As 

30 stated above, the message will be formatted to comply 
with the exchanges CTCI rules . When the new message is 
sent, it is added to the unacknowledged message queue 
(step 511) . 

The CTCI routine determines if any new data has 
35 been received from the exchange (step 512) . If no new 
data has been received, the CTCI routine continues from 
step 504. If new data has been received, the CTCI 
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routine determines if it matches any message sent that is 
listed in the unacknowledged message queue (step 513) . 
If so, that message is removed from the unacknowledged 
message queue (step 514) . The CTCI routine examines each 
5 message received from the exchange and updates the tables 
in the database 6 accordingly (step 515) . 

Steps 516 and 517 of Fig. 16 are applicable 
only to communi cat ions with Instinet. As Instinet 
provides for two-way co mmun ication between the Instinet 

10 processor 46 of the control engine 2 and the Instinet 
system 10, execution information is received and 
processed by the CTCI routine. (For other exchanges, 
such as the NYSE DOT system 8, execution information is 
received and processed by the print capture routine 

15 discussed below with reference to Fig. 17). Thus, if the 
CTCI routine is operating on the " Instinet processor 46, 
the CTCI routine will determine if the message that is 
received is an execution report (step 516). (All 
messages received are stored as unprocessed messages in 

20 the database 6, and are marked as unprocessed. The 

execution information that is received is processed by 
the execution routine, discussed in detail below with 
reference to Fig. 18.) If the message received is an 
execution report, the CTCI routine sends an Iserv-J 

25 message to the CTCI new message queue for transmission to 
Instinet 10. The Iserv-J message is a message that must: 
be sent to Instinet in response to a trade execution. 
(An Iserv-J message confirms that the control engine 2 
received the execution report, and is required .by 
.30 Instinet.) 

Turning now to Fig. 17, there is illustrated in 
flow chart form the steps performed by the print capture 
routine. The print capture routine enables the control 
engine 2 to receive execution information from exchanges 
35 and electronic trading systems that only provide this 
information over a separate data line to a printer. 
Typically, in systems such as the DOT system 8, execution 
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information is sent by DOT to a printer at the broker's 
backoff ice. The execution information is then printed, 
and manually entered into the broker's accounting system. 
Moreover, this type of reporting system does not 
5 correlate the execution information received with the 
orders sent for execution. The print capture routine of 
the present invention "captures" the execution 
information and uses it to automatically update the 
database 6 so that the execution information is 

10 correlated automatically with order information and so 
that the execution information can be manipulated, at the 
user workstation 4. 

The print capture routine is executed by a 
dedicated processor. For example, for the DOT system 8, 

15 the print capture routine is executed by the DOT In 

processor 54. For the CSE 12, the print capture routine 
is executed by the CSE In processor 60. 

In the representative embodiment, the print 
capture routine is run from a batch file from the 

20 Microsoft DOS operating system of the processor (step 

602) . A DOS text file is maintained to log each message 
received from the exchange (step 604) . On setup, the 
print capture routine reads stored port configuration 
information, for example, from a DOS file (step 606) . 

25 The communication port of the dedicated processor is then 
initialized (step 608) . 

The print capture routine can be terminated, 
for example, by a systems administrator (steps 610 and 
612).. In the representative embodiment, the print 

30 capture routine is terminated by pressing the ESC key on 
a keyboard associated with the dedicated processor. 

The print capture process determines if there 
is any inbound data on the communications line (step 
614) . If there is inbound data, the print capture 

35 process reads the inbound data from the communications 
line, formats it and updates the database 6 (step 616) . 
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Tfce inbound data is stored as an unprocessed message in 
the database 6, marked as unprocessed. . 

Turning now to Pig. 18, there is. illustrated in 
flow chart form the steps performed by the execution 
routine of the control engine 2. The execution routine 
is executed by the execution processor 34. The execution 
routing inter alia, processes the messages and execution 
r eporta received from the various exchanges and automated 
trading system. the ^tion 

routine is run from a batch file from ^™ 0 ^ D ^ t 
operating system of the processor (step 702) A DOS text 
f ile- is maintained to log each message processed by the 
execution routine (step 704) . 
» The execution routine can be terminated, for 

" example, by a systems administrator (step 706). In the 
representative embodiment, the execution routine is 
terminated by pressing the ESC key on a keyboard 
associated with the dedicated processor. ^ 

The execution routine determines if it .« time 
to purge information in the database 6. If the preset 
mrae time is reached, the execution routine will 
purge time is maram wi n be executed (steps 708 

terminate and a purge program will ne e 
and 710) . Upon completion of the daily purge, the 
25 execution routine is restarted. 

The execution routine determines if there are 
any unprocessed messages that have been received from an 
exchange or automated trading system (Step 7IM. As 
stated above, unprocessed messages ^^TJTs 
exchanges are stored in ^ ^ *f ~ ffl ^ 
unprocessed. An unprocessed message is seie 
database 6 for processing (step 714). 

The execution routine determines the 
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Tne exei.ui.iuw *. ■ 

unprocessed message's message type (step 716,. Possxnie 
35 ..essage types include execution report, order ^ 
acknowledgement and reject. At this stage the message 

v. * nma r specified by the exchange s 
is still in the format specirieu ^ 
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"message protocol. Accordingly, the execution routine, in 
carrying .out this step, examines the message to determine 
what exchange it was received from and thereafter parses 
the fields of the message according to the format 
5 specified by the exchange's message protocol to determine 
the message type (step 718) . . 

If the message type is an execution report 
(step 720) , the order tables in the database 6 are 
updated as follows: 
10 a - If the executed quantity equals the order 

quantity, then the execution routine changes 
the status of the order in the database 6 to 
"executed". 

b. If the executed quantity is less than the 
15 order quantity and the order has the. current 

status of "new" (i.e., not yet acknowledged) , 
then the execution routine changes the status 
of the order in the database 6 to "active". 
The database is accordingly updated with the 
20 new status information for the selected order, the 

database is updated with the other execution information 
in the format required by the database 6 and the 
unprocessed message is deleted (step 726) . 

If the message type is not an execution report 
25 (step 720), the order tables in the database 6 are 
updated as follows: 

a. If the message is a reject message, caused 
by no response from the exchange, and the order 
has the current status of "new", then the 

30 ^execution routine changes the status of the 

order in the database 6 to "held". 

b. If the message is a reject caused by no 
response from the exchange, and the order has a 
status of "active", then the execution routine 

35 changes all order information to be the same as 

it was at the last known good status. The CTCI 
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exchange, and the or . routine changes 
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the status of the 
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. order in the ."s ^n execution 

■ - ^ r m Ousted trade) an, the order 
m essage (i.e. for BexeCUt ed«, then the 

has the current status ^ . 

order in the data^ ^ M r 
the order quantity _ inCer vening 
execution- quantity, less any 

cr ades.) conmuniC ated between the 

mformation can b tation 4 using the 

, rnl eIi qine-2 and each user exchanged, 
control engm ^formation that is 

following techniques The ^ ^ mention information,- 
for example, , order xntorm* _ e embodiment, . 

. v_ _ j.rabase © ■ x " -i otl 
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for example, , order informa emDod iment, . 

is stored in the database I. ^ worlt8ta tion 

information exchanges are driven prQceSS l00 

4 . For example, when the o ^ eQg . ne in 

nee ds to supply ^^^X/^nagement process 100 
relation to an order, the order ^ . g a rQW 

formats an appropriate ^ the database acts 

in one of the ^£ ^ add ed to the table by, 
as a queue. When informatio i- g ^ aC che use 
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„ a queue. when ^""^ proc ess x°0 at the user 
£or e*a»nle. the J^rocessed or new 

^station, that row » at the control engme * 

■me processor (e.g. «. « OI ^ g the order in the 

ne w message queue) . 
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and if fi* ds one ' 



o rows and it tmas 

retrieves that information 
step 509 of Fig. 16).. - reC eives information 

The user — »"»^y examining certain 
£r om'the control m9in to 7ee if information has heen 
cahles in the by the execution processor 

added ro a tahle «« £ ^„ ion grating on the 

34) that concerns a process ^ ^ ^ ^ ln tn e 

us er .creation 4. = on the user 

a»»« 6 - " foI matic.n. it examines the 

^station ^ -tTcUe « (- — » S °" 
appropriate aoor opriate informatron. 

^ery) retrieves the approp che con crol 

la an alternative emh^ tion co . user 

, engine 2 can he designed to ^ iogs „ — 

workstation 4 ^/rTtlon concerning the processes 

. thereafter when new - £ °^ cacion 4 i, received hy 
or functions runnrng on a wo 

'the control engine 2. representative 
The booth worKstatxon 14 ^ ^ ^ 

" ^odimenc is a user interface. 

VJ C j:ZZ ~ the hooth station » 
The processes per ^ proces3 , a save 

include a log -on P*°«* S ' , prince r process. 

„ proC ess. an orders proces ~ d 5 order3 ro uted from 
" P . The printer process al d on a 

ch e control engine 4 to he ^J K!K , typically 
priM window^ - -"^orders to he executed from 

30 ^printer or the P^'^hows the sca tus of order, 
The orders process sn process 

routed to this hooth — ^ on a scre en display 
displays the ■»™'j£ w tbe giDil a r in format and contents 
called an orders ""f^scussed at Figs. 10-12 ahove. 
35 to the BV window 2S0 pediment, when the 

In che representatr ^ ^ ^ 

order has heen executed or 
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workstation 14 wishes to update the status of an order 
that has been sent to the booth workstation for . 
execution,, the user will simply click on the order as 
displayed in the Orders Window. The user will then, for 
5 • example, fill in the execution price and execution 
quantity. The status of the order will, where 
appropriate, change to executed. The user will then 
select. a save icon, causing execution of the save changes 
process. 

10 'The save changes process, if selected by the 

user at the booth workstation 14, writes the new 
information to the database 6 at the control engine 2. 
The modified information will then be queued by the 
control engine so that it can be sent to the correct 

15 user's user workstation 4 for display. 

The system of the present invention allows easy 
manipulation of order and execution information. The 
database G of the present invention stores information 
concerning orders and executions and thereby allows 

20 users, at a user workstation 4, to retrieve and sort this 
information, allocate executions to specific accounts, 
determine the average price for an order and perform 
other back office functions without having to reenter any 
information. Accordingly, the present invention 

25 integrates trading with existing portfolio management and 
back office systems, thereby creating a "paperless 
transaction. " 

A Trade Blotter function will be discussed as 
am example of a back office function that can be 

30 performed by the system of the present invention. The 
Trade Blotter function is executed by the user 
workstation 4 of the present invention. The Trade 
Blatter function allows entry of trade allocations for 
the current day's trades. The Trade Blotter is activated; 

35 by selecting a Trade Blotter Icon from the Window 
operating system level. 
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9 . purchase and s u buy6 , cover 

application generate, , a repo« * ^ ^ 

£rcs. sells and sell ^ £ „ the current dny 

— ■ j^r^s.' — ° £ tey report - 

r^ical end of da* ^^aon. 

»•■ "-""i cosmission report fro- 
- UC "c^ssrr=o a rrcreated hy - -de Blotter 
broker commissio" 

— ' 10 . stoca Split, -^tionHn tne 
application creates ^J^. . for a split date. 
Transactions record of t* tion . Tnrs 

U. create Prrces PP ^ ^ 6 by 

, application updates the s ^ox^tion from 

cne application progr» that ^ io[0 »ao. If- 

the online source of price so che 

The updated prices ar< ^ che » rl «t 

unreality Report applxcatr 
10 value of each V^'^^. This application 
»• TioM balances , positions and 

aownloads daily tra ° 3a ="°° s ' ign aced clearing entity and 
account changes from the design ^ ^ cle arrng 
upi aces the angine 2 of the present 

, 5 entity is coupled to the fotMlt ian shout the 

invention end is ^^esignated clearing entrty 
executed orders. The 
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th en perform the regular clearing function for those 

trad6S - Accordingly, the present invention includes a 
i -ralitv of computer-to-cc*nputer interfaces, each to a 
plurality ° f ™ y sophisticated user interface; a 
source of liquidity , a ^ * ag the FOE 

^^h-r 0 f -front-end" applications , 
number or office- applications, 

system; and numerous -back- office PP 
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WTTRT T5 CLAIMED IS : 

A computerized order entry, routing and 
reporting system for receiving and routing an order that 
includes order information to an electronic trading 
system and for reporting execution information including 
information about the execution of the order on the 
electronic trading system, the system comprising: 

a control engine coupled to a plurality of 
electronic trading systems; and 

a user workstation coupled to the control 
engine, the usfcr workstation including a screen display, 
the user workstation receiving the order and 
electronically transmitting the order to the control 
engine and displaying the order information on the screen 
display; 

the control engine, upon receipt of the order 
from the user workstation, automatically and 
electronically routes the order to one of the plurality 
of electronic trading systems, and electronically 
receives the execution information concerning the order 
from the one of the plurality of electronic trading 
systems , 

the control engine automatically correlating 
the execution information with the order information and 
electronically transmitting the execution information to 
the user workstation., 

the user workstation displaying the execution 
information correlated with the displayed order 
information. r\ 

2. The order entry, routing and reporting system 

of claim 1 wherein the order is received by the user 
workstation from a user. 
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r der entry, routing and reporting system 
% claiB Tletrre order " receive, . - neer . 

Lotion t ro» an e^ert evete... 

o£ cl aim i -tLtp^ta area networK. 

user workstation by a pri 

6 TO e order -rv. -ting a^^g -a- 

user workstation by a wia 

^ routing and reporting system 

use r workstation by a modem. 

TO e order entry, routing^ 

,: £ clai m i --rr^rt^tion. 

a different color to tne 

border entry, routing and reporting system. 
■ r^ciaim herein tne order inciudes^antrty 

information. 

order entry, routing and report-g system 
^'ciaim herein tne order inciudes routrng 
information. 
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„ luting and reporting system 
i2 « order J^^^ Qood «U 

of claim 1 wherexn the 



information- 

„ entry routing and reporting system 
^ e °Tn Reorder is a border. 
of claim 1- wherein the 

^trv routing and reporting system 
The order entry, ro 
14 • •« t-tie order is a sex J. 

of claim l wherein the 

routing and reporting system 
The order entry, 8bott order. _ 

15 • rte order is a sen 

of claim 1 wherein the o 

* entry rooting ana reporting system 

anting and reporting system 
The order entry^ routing ^ ^ 

o£ claim 1 wherein the order 

routing and reporting system 

orders an orders an option. 

of claim 1 wneiC 

routing and reporting system 
i9 . The order entry ^-t ^ ^ ^ & ^ 

of claim 1 wherein the or 

'outing and reporting system 
-^.^errr^salotderiora.tnre. 

of claim 1 wnetc 

der entry, routing and reporting system 
The order entxy^ ^ f<jr a 

of claim 1 wherein the order 
derivative . 

routing and reporting system 

»■ ~ ^rth^ert an order for currency, 

of claim l wherein the o 
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nt „ routing and reporting system 

»• ™ 0rdeI " «« workstation U further 

oE claim 1 where, ^ ^ ta£ormatio n. 

coupled to an on-lrne 

routing and reporting system 
Toe order entry routing ^ ^ 

"porting system eooS ' r ^% ouplld „ a plurality of 

a control engine ooup including 

el ectroni= trading systems. 

a database; and _ q coupled co the control 
a -er .or^rarr tbe u3 er 

display; .aoiM. upon receipt of the order 

the control engiae, L the order in <*e 
w „ a or workstation, stores tes the 

from the user wo anQ ele ctronically ro 

database, and of ele ctronic trading 

order to one of the P**^^. an execution report 
systems, and electron^llY ^ ronic cra ding system, 

concerning the order ^ ^ and 

stores the ^es information in the 

automatically and elect fco the use r , 

stored execution . Q the stored execution 

workstation, the «f °^ly cransmitted hy the control 
report being electronically t 

,»,» user workstation, information 
engine to the user displaying the inform* 

the user workstation ^ display 

rd^rrtn-p^ormation ahout the order. 

„ real-time order entry, routing 
A computerized rea ^ an orde r 

and reporting system for 
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rlrm 'to an electronic trading 
tha t includes order ^ inf oraat ion including 

. system and for of the order on the 

information about the «- cu comprising: 

electronic trading eystema ; /™L, led to the control 

en S i«. the ueer tt e order and 

the user «*- 8 "^^ tie order to the control 

electronically trane-tt _ g^^ ^ OIter 

electronically routes el ectronioaUV 
o£ electronic: tradrn, ■»£^ -ootioo information 
t eceives. in real—a the e ^ 
eoaceming the order ***** execution information 
. electronic trading ""^^with the order inror»tron 
-rai=Ic^^e, hy the dontrol engrne 

. T-oai-time on tne 
^Ti^aved order motion. 

, colorized order entry. thac 
Reporting eyste, tor receiving » d c tra4i ng 

. Eludes order inroraacro ^ *° iniorto tion includrng 
\ reporting executio 

system and for r p utio n of the order o 

■ ^formation about the exe comp risxng: 

el ectronic trading systems ; the con trol 

a user workstation screen display, 

oot workstation including 
engine, the user work order and 

th e user workstation recei 
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. tcing the order to the control 
electronically. inf orroa tion- on the screen 

engine and displaying the 

display; being responsive to receipt 

^ ^Vuser workstation to automatically 
of the order from the use ^ ^ q£ ^ 

^d electronically rou te the^ ^ ^ coQtrol 

polity of electronxc trad,n g ^ ^ n 

engine ^'f^^T*. one of the plurality of 
concerning the order fr respo nsive to 

el ectronic trading ^^tion to electronically 

- ceipt — to the user 

transmit the recei inf0 rmation being 

^station, the «~ in£0imati ° n 

di3pW on the sc 

displayed order information. 

X con*uceri«d order entry, routins and 
repo rtin 9 -^r^rUed to a plurality of 

eiectronic -«*2LtwW a screen display, 
a user workstatio wor kstation 

coupled co the -<"^ e ^ Electronically 
receiving as input an ^ and 

cranssdtting the order « on the screen 

paying ^ttion ahout the order is 

display such that display; 
— - :Uae. u.n re e - the order 

front the user ^^l l f cue plurality 
electronically routes the ironically 
o£ electronic relate d to the order from 

r eceives execution rnfor^tron^^ 

th e cne ° £ ^^"electronically transits the 

• csS^- the u3er work9 ' 
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^ ^er vo^on a^L^ - --- he 

-son about the order, 
information aou 

29 A computerised order entry, -ting - 

— ing rr«:rS- -P-a - . ****** - 

eiectronit trading ^^uding » screen 

a user workstation ^ ^^^ic 

coupled to tne ^^T^ eleotronioally 

receiving as input an order ^ ^ ^ 

cransmitting tne order t^ ^ ^ _ ^ n 
displays ^^^rsation anout tne order » 

display suoh that tn di splay : 

displayed on one irne oyne ^ q£ the orfer 

the control engx „4-.iiv and 

froffl the user — ^ of .e.P^V 
electronically routes the elec tronically 
of electronic trading systems, an^ ^ ^ ^ from 
deceives execution ^^^ronic trading systems, 
t he one of the plural-* °* formation wxth 

automatically c^ 61 ^ 6 * auCOffi atically and 

t he order information, —J^^ formation to the 

el ectronically transmits the 

U3 er workstation, ^. Qn disp laying the execution 

' ttl e user vorKStati display as the 

«r, the same line of tne b 
information on the 
information ahout the order. 

^^■r entry, routing and 
M . ' * c~*~»*j£i fronting an orde* that 
reporting system for elec troni= trading 

JUes order ^ £ °™"°" ^ion information ineludxng 
. system and for o£ the or der on tne 

information about the exec c omprismg = 

eleotronic^sy-. ^ „ „ elec croni= 

rrading system; and 

tracing S0002944 
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.„uv transmitting the oru screen 
electronically tran information on trie 

engin e and displays the 

tne control ^.^n-e^t.. ore 

fr c the user Ration, auto- i^ y^^ ^ 
electronically routes the ^ execution 

sy ste». and elactronrcaW ^ ^ ^ ele ccrom= 

user workstation. displaying the execution 

the user woricst ati liC ,d with the 

information on the screen display 
displayed order intention. 

reporting system for receiv g lc tra drng 

• includes order ^=-^0 » ^ 4in9 

system and for ~P°~^tion o£ the order on the 
information about the ex ^ cOTprisl ng-. 

coupled to a plurality of 

electronic -^J^Ln couplad to the control' 

* . . first screen display; 

engine and including a first ^ ^ concro l 

a second worlcstatio n ^ ^ 9econ a 

engine and including a -"^^ electronically 
^station receiving the ord . ^ caus 

transmitting the "^^ed on the first screen 

. che order information to be di 

diSPlaVi . octroi engine, upon receipt of the order 

the control eg t0Bat ieally and 

£ rom the second workstation, auto 
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to one o£ the plurality 
electronically routes the ot^ eleccro nically 
o£ electronic concerning the crder 

r eceives the -—"^tTof electronic trading 
tr oa the one of the P^ l ^ fcion bein3 automatically 
sy sce»s. the ^"^^o.nation and electronically 

infection on ^ q> 
the displayed order m 

claim 31 wherein the second 
_ 2 The system of claim \ to be displayed 

■ ^uaes the order information t 
workstation causes 
on the second display screen. 

of claim 31 wherein the second 
»■ • ^ars^e -cution information to he 

W r^ron C r second display screen. 

3, * ^ i2e : e ^:; ^r^- - 

porting ^'Z^T****** -din, systems 
include order « for »"" inf orm ation including 
-d for -^^X^tion of the orders on the 
information about the ex comprising: 
electronic^sy^^ ^ M of 

engine, the user — ^f^W ° £ ^ ^ 
the user 

workstation recede . ^ to 

exectronically trans*; order information for 
the control engine and to splay ^ ^ display; 
each of the Plural^ of ord ^ q£ ^ 

the control e g workst ation, 
piurality of orders from each one of the 

automatically and electronically 
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, rf ers to a different one of the plurality 
plurality o£ order to ele ctronically 
o£ electronic trading concerning each one of 

receives the execut- i ^ q£ electronic 
the plurality of orders^ correlating the 

ceding system, the contro^ g ^ q£ Qriers 

execution information for eac ^ plutalicy o£ 

ulcb the order ^^^ndtting the execution 
orders and ^^^U plurality of orders to the 
information for eacn 

use r workstation. . . displayi ng the execution 

th e user workS "" corr elated with the 

information on the screen display 

order information. 

reporting system for recer 9 trading 
incl udes order »»-«-«^ I ^f tato -«l» 
sya tem and for o£ the order on the 

tuformation about tn comprising: 

electronic^sy^. ^ ^ ^ o£ 

engine, the user - 

one user station --^Trder to the control 

electronically transmitting the 

» 3lM! che control engine, upon receipt of the order 
£ rom the user workstation \ t the plurality 

electronically routes the elec tronically 
o£ electronic trading -^"^ conC eming the order 
receives the — electronic trading 
from the one of tne pj- 

9ys tems, , automatically correlating 

th e control, engine a informat ion and 

the execution information w,th the or 
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, tting the execution infection 
electronically transmitting 

the user workstation, disp iaying the order 

the user ««* Bta ^° ^ displaying the 

lotion, on -J^Sd^ta *- displayed order 
execution information 
• information- 

antrv routing and 
A =o*u«rized order ^ ^ oraer tfcac 

reporting system for «~^ 9 ^iectronic .radio, 
Eludes order ^^"^ution information including 
sy sce» and for ^^ ion o£ the order on toe 
information about the ex COT prismg-. 

electronic trading '^Tj^M to the control 

a user station co p & fl . splay , 

engine, the user -or* orde r and a routing 
rbe user workstation «cervi g iaeMi£y ing one of 

^ruction, the ding system .and 

che pmraiity of ^« r ; n ;; the ordet „ =°«f 

electronically transmi tcing ^ che 
engine and display^ the 

routing instruction on the a q£ tBe order 

the oontrol -P-^ ^ 

front the user vorfcstatron. auto ^ ^ 

-,-»llv routes the order to t iEied by the 
electronically ro t ,, ding eystems identiti 

piurality of - le « r0nl % tr e f eccroIli oally receives, the 
Luting instruction, and electro £rOT t he one 

locution infection concerning che^ ed 
oE che plurality of ^ ectr011 " ex e CU rio» informatron 
by Che routing the order infor»tr°n 

b eing automatically by che control engrne to 

^ electronically ^^ay on . the display devrce 
- th e user worhsta tron «r ^' ^ 
with the displayed order 
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ontrv routing and 
A cauterized order entry, 

Reporting system comprising : & piurality of 

a control engine engin e including 

ele ctronic trading systems. 

a database; ..aerating an order; a" 

an expert ^ 9e °* coup ling the control 
a user -orKstatron rntere P 

engiM and the expert user Wscation 

— trxT: u e^ert r r r concrol ; 

receiving the tting cM order to th ^ 

£r om the -r wor^tat^. "-.^ ronically rouces rt e 
d atabase. and auto»*ticaUy ^ cradmg 

or der to one of toe P^"^. an execution report 
„r,rt electronically r ei - trading system, 

systems, and rom the electronic trading 

concerning the order « da tabase and 

automatically and electr „ the u9e r 

stored execution report avail execution 

• n the information m the s control 
workstation, the i tranS mitted by the c 

„ort being electronically 

to tie user ™^ 

ch e user worKstati on the screen 

the information in the ^ the order, 

display adjacent to the 

»• > ^^Woul^ «der that 

— XrJr^-an electronic ; trad^ 
includes order 111 execution information 

system and for report^ f che order on the 

information about the ex comprising: 
— coupled to a plurality <* 

electronic trading systems; 

S0002949 
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mert Bys tem for processing execution ' 
an expert syst or der- and 

information and tor «^*^ pi- to the control • 
a US er workstation P TOtMC «ion 

engine end the ^^user workstation 

including a screen «*"^ sy3Mn . 
receiving Che order from Che the con trol 

.„,,„ transmitting CM 01 order 
electronically trans ^formation for Che o 

engin e and displays Che 

on Che a=« en : diSPlai : : . M ine. upon receipc of Che order 

<*• COnCt °\mucoLci=ally and 
trom rhe user Workstation, au ^ q£ ^ plurallty 

el eccronically rouces Che ele « r0 ni=ally 

o£ electronic ^ ^^ tion concerning Che order 

receives Che execution informa ^ trading 

from Che one of Che P 1 ^"* betog automatically 
sys cems . Che execucion inf ormatio ^ electronica lly 

. correlaced wich Che orde rnfo ^ ^ ^ uork3tatl on 
cransmicced hy Che control eng ced 

for display on Che ^J^smission hy Che user 
order information and for cr 
workscacion co Che expert syscem 

rout i-Gg a.nd 

reporting system for receding nic crading 

includes order ^"'^on information including 
sys cem and for «*°«^ tion o£ the order on the 
information about the ex com prising-. 

«— V2£.t£ - a pluralicy ° £ 

— rairy^-r order to the control 

— the control engine, up^ receipt^f the order 

from the user workstation^ auto ^ ^ 

electronically routes Che order 
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and electronically 
o£ electrode «^'^ cion co.cer.in, ^ «~ , 
receives tne -^7x-Uc y o< electronic tradms 
from the one of the p 

— „ ccc ^^TLSST- 

^c^-a^e to ac expert 

reporting «« r *" V £ , „ electronic tradins 

include, order inroraatio^ to in£oCT ation include 

sy3 te, and for o£ the order ou one 

information about tM comprising: 

^ user workstation, automa plurality 
from the user r tQ one o£ cue ^ 

electronically routes the eleCcr onically 

6 of electronic «^ conC emin g the or.er 

receives the — ^^° tef of electronic tra*in 9 

from the one of the p 

Che user workstation, electronically 

the user vorlcstatro ^ expert 

cransndttino tne execution rnror^tro . 
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sy ,te» - ""I" I'cion of order on the 
intonation about Che ex compr ising = 

el ectroni= ^^taTiontoupled » the control 

a user » orketat otem , the user 

MgiM and ^ 1UdiB9 " Hrder and electronically 
workstation receavxng the 

«ansmicting the order to Jh ^ o£ che order 

tu control »^; J atlcaUy and 
£r o» the user o'er to one o< the plurality 

electronically routes the eleccro nically 
o£ electronic trading concOT in g the order 

— r tntTluraUtTo, electronic trading 
from the one of tna P 

the control -^^^^^ 
* — X SSTt execntion in.or.tion to 
electronically 

the use r worltStati ° n ' rlcgtati on electronically 
^ttinT r^ion motion CO the expert 
system in real-time. 

. ^ entry, routing and 
12 _ . > «^" riMd °^g and routing an order that 

reporting system £or ~« 1 ™ 3 el eccronic trading 
Includes order i^^J^ion infection include 
sys te» and for = £ the order on the 

information about the exe prising: 

electronic trading . ~* co tne control 

a user workstation * otde r and 

engine, the user workstation recer-ng 
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— the control engine. u P ot - — . 

from the user -"f*^ „ of 
electronically routes the elec tronically 
o£ electronic concerning ^ 

"The plurality =f electronic trading 
from the one of tne P 

electronically 

the user workstation _ q the execution 

reporting system for recei s eleetr onic trading 

deludes — ""^TexecoTion information inching 
syste» snd f or rsport^cut ^ ^ orier on cfte 

intonation about <*, conp rising: 
eleetronic^g^- ^ tQ . plur elity of 

. electronic trading syst^and he =omrol 

s nser Program, the nser 

workstation recei a coacr ol engine; 

transmitting the order to the q£ 
the oontroi ^; co ^ ticaUy and 
rrom the nser workstation, aut ^ ^ ^ ^ 
electronically rentes the electr onically 
o£ electronic trading W*^^ conce ming the order 
receives the e-cution -^ -ctronic trading 
from the one of tne p 
systems, automatically correlating 

^rmirn with the order informa-n an, 
the execution mformatxo ^ 
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. . M the execution information to 
eXeccroniClly transmitting 

the u 3 er workstation, ele ctronically 
program in real-time. 

entry, routing and 

reporting =Y«e» *« reC " electronic tradrng 

I^udes order »-«-^J^L, motion 
By ete» and tor ^^ tion o£ Che order on the 
^formation, about the ex canE , r i 61 »g: 

electronic trading to roe control 

» user workstatro order and 

electronically trans 

. . «f the order 
en9ine: control engine, upon recexpt of th 

cue control eng lcaUy and 

£r o» the user wor.stat.on a«o ^ ^ ^ pluralxcy 
electronically routes the orde ronica lly 

electronic trading n*-^ concemi ng the order 
receives the execu-n tr adrng . 
from- the one of the p ^ 

SySteM - the control engine "^U^ and 
ch e execution i^ the -cution motion to 

electronically transmitting 
- V the user workstation, the execution 

_ .r.xrr. — .— 

or.trv routing and 
X computerized order an order that 

reporting system for Electronic trading 

deludes order ^^"on information include 
sy gtem and for reporting ex. 

syS S000295 
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' the execution of the °rder on the 
information about the ex comp rising: 

electronic trading - d ^ ^ 

a ueer .otMUUonc P WOElus cation 

■„. and to a neural network, tn cran3mic ting the 
'Tee the order and electronically t 

c0 " 101 I autOT atically and 
from the user ' to one of the P^-V 

electronically routes tna or ronica lly 

e o£ electronic trading , concemtBg th e order 

receives the . o< electronic cradmg 

- from the one of * 

electronxcaixy 

th e user worlC9tati ° n ' tatio n electronically 

the user wor ^^ tX infornatio n to the neural 
emitting the execution xnforma 
• network in real-time. 

entry, routing and 
. 46 . * =«7f r t^; Boutin, an order that 

reporting system tor recerv g ^ tradin g 

diodes order ""^Tcution intention inc^drng 
sy sce» and tor ^"^^on of the order on the 

iS^U 1 :^"- Plurality o. 

electronic trading systems; tne con trol 

engine, the user vorK-t ^ and 
-rl^r toting the order to the control 
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. ^ orter tM screen 

engine - ^ 

^ rt e c=«r=X en 9 ine. upon re-P-- 
i.ctronicaUy routes the ore electro nically 

reives the £t ty of «— ? 

W OM . llv corr elating 

™— ■ che control Lotion and 

tbe user taCion displaying the execution 



i 



information. ^ 

A computerised order «oer that 

4 tor receiving ano i floor ot an 
sporting system for broker on the f loo 

include, order information to in£oCT ation 

Change and for reputing exe q£ che ord er. 
Eluding information abou 

svstem comprising. 

the 6Y . control engine, ^ coupled to 

a booth workstation el o£ ^ 

- — ^ht^:— --ruser 
exchange, tW * displa y wxch a g 

printer and a £3.r 

control engine the —^station receiving - 
second screen display. ^ cln g the order to the 
orteI and --^Xing the order information 

the control y auComaC ically and S0002956 
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to the booth workstation 
el eccronically -^VU attached ^ "* 
uher e the ord« d . splay , ^ 

displayed on tne ■ n receiving the exe 

the boot* workstation ^ graptlica l user 

information concerning ^« ^ el ectronically 

r.^:- = ~~ 

engine. , , naiM receiving the executron 

the control ^ cbe ^cren _ 

ill£ or»tion. aut-aticaUy =- ormaCion ^ .^ccronrcally 

workstation, worksta tion displaying the •» c *""°* 

the user worlCS ^^ creen with the displayed order 
«n the second screen 
infomation on tne s 



information 



,„ rrv routing, and 

horning sysce* tor for reporting execution 

deludes order -^o^ion afcout the — °< 
^cion cMprisiDg: 
the order, the By»^ 

a control engme; aical ly coupler to 

a- trading workstation ^station deluding a 
ch e control ongme. the ^ ^twl »=er 

£ir st inpnt/output devrce ha 

interface; ana ele ctronically coupled 

a us er «r^t- includin g a 

Che control engine, tne workstation 

Lcond inpnt/output device the^ d ic e and 

receiving the order at *\ to che control . 

electronically «--^ ° D ** 

engine and displaymg the 

in put/outpnt device, recelpt £ cue order 

decontrol eg ically and 

f rod the user wor« .tatron ^ ^ 

electronically routes the s0 0<rt951 
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,, the first input/output device 
nation for output^ ' tlflo elecC roni=ally 

£o r execution. Che concer ning execution of 

receiving -^"f^fCcyoutput device, the trading 
ch e order at the far. -J* the execution 

„ orks cation electron.^ t 

information to the control eng ^ 
infection heing the lafoo-tiaB d 

- ^ThtTeer — coated 

• n *t the second input/output devi 
information at the information . 
with the displayed order i 

X computerized order entry, routing and 
49. A ^ „ aWtna and routing an 

reporting system for £or report ing execution 

el ectronic trading WBtemsi rkstltl ons 

a Plurality of hooth ^ 

el ectronically =° u * le * "J^etious including an attached. 
tbe plurality , ~^ lay wlt h a graphical user 

printer and a rii» 

interface; and ele ctronically coupled to 

a uaer workstatio including a 

the control engine, the -"^station receiv ing the 
second ecreen display, the u ^ ^formation 

ord er and routing ^» ^ 5yste , or hooth 
including the electronic «£W y ^ 
„orhstation to which th orde* the rou ting 

eleccronically Z~ - 

information to the . second screen display; 
. or der information on these" ^ ^ ^ 

the control engine, P worlcsCat ion. 
routing information from the user 
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automatically and electronically routes the order to the 
electronic trading system or booth workstation specified 
in the routing information, and receives at the control 
engine the execution information from the electronic 
trading system or booth workstation specified m the 
routing information, and automatically correlates the 
order information and the execution information, and 
electronically transmits the execution information to the 

user workstation, 

the user workstation displaying the execution 
information correlated with the order information on the 
second screen display of the user workstation. 

50 . a computerized order entry, routing and 

reporting system comprising: 

a control engine coupled to a plurality of 

electronic trading systems; and 

a user workstation coupled. to the control 
engine and operated by a user, the user workstation 
including a screen display, the user workstation 
receiving an order from the user and electronically 
transmitting the order to the control engine and 
displaying information about the order on the screen 
display; 

the control engine, upon receipt of the order 
from the user workstation, automatically and 
electronically routes the order to one of the plurality 
of electronic trading systems, and electronically 
receives execution information concerning the order from- 
the one of the plurality of electronic trading systems, 
the execution information being electronically 
transmitted by the control engine to the user workstation 
for display to the user on the screen display. 

51 A user workstation for the entry order 

information and the display of order and execution 
information, the user workstation coupled to at least one 
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_ m the user workstation 
electronic trading system, tn 

comprising: 

. , couple d co tb. processor. 

SSL. - — T Z i£— concrolled .V « 
a graphical ussr fling a n order entry 

prooes .or. coe ***** J" S~ -»« ° rder ^ 
window for receivino order r ^ ^ in£orMClon 

oocc-vie. -fTjfJ^ an execution for cae 
and execution information 

«ans*iccin 9 «- «— ^rreal ciL and receiving 
52 x user nation for -e 

" £ oraation and tne ^^'coupied a piuraiity of 
in£ or*ati=n. the user »or*sta wocMcaClo n 
eieccronic craning synced. 

comprising: 

a processor; ^ proceSSO r. 

~ Tr ---- to che P-alitV of 

:trrnir^ 

a graphical user ^ teT an ord er entry 

the graphical user including ^ 

and execution inform* 

order. S0002960 
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the computer interface electronically 
transmitting the order information to one of the 
plurality of electronic trading systems in real-time and 
receiving the execution information from the one of the 
plurality of electronic trading systems in real time, 
the graphical user interface displaying the 
order information and the execution information on one 
line of the book-view window in real-time. 

53 A user workstation for the entry order 

information and the display of order and execution 
information, the user workstation coupled to a plurality 
of electronic trading systems, the user workstation 

comprising : 

a processor coupled to a plurality of 

electronic trading systems; and 

a graphical user interface controlled by the 
processor, the graphical user including an order entry 
window for receiving order information about an order and 
a book-view window for displaying the order information 
and execution information about an execution for the 
order, 

the processor electronically transmitting the 
order information to one of the plurality of electronic 
trading systems in real-time and receiving the execution 
information from the one of the plurality of electronic 
trading systems in real time, 

the graphical user interface displaying the 
order information and the execution information on one 
line of the book- view window in real-time. 

54 A user workstation for the entry order 

information and the display of order and execution 
information, the user workstation coupled to a plurality 
of electronic trading systems, the user workstation 
comprising: 

S0002961 
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a processor coupled to a plurality of 
electronic trading systems; and 

" a graphical user. interface controlled by the 
processor, the graphical user including an order entry 
window for receiving order information and routing 
information for an order and a book-view window for 
displaying the order information and execution 
information about an execution for the order,. 

the processor electronically transmitting the 
order information to one of the plurality of electronic 
trading systems as determined by the routing information 
and receiving the execution information from the one of 
the plurality of electronic trading systems, 

the graphical user interface displaying the 
order information and the execution information on one 
line of the book- view window. 

55. a user workstation for the entry order 

information and the display of order and execution 
information, the user workstation coupled a plurality of 
electronic trading systems, the user workstation 
comprising: 

a processor coupled to a plurality of 
electronic trading systems; and - 

a graphical user interface controlled by the 
processor, the graphical user including an order entry 
window for receiving order information about an order and 
a book-view window for displaying the order information 
and execution information about an execution for the 
order , 

the. processor electronically transmitting the 
order information to one of the plurality of electronic 
trading systems in real-time and receiving the execution 
information from the one of the plurality of electronic 
trading systems in real time, 
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the graphical user interface displaying the 
order information correlated with the execution 
information on the book- view window in real-time. 

56 A user workstation for the entry order 

information and the display of order and execution 
information, the user workstation coupled a plurality of 
electronic trading systems, the user workstation 

comprising: 

a processor coupled to. a plurality of 

electronic trading systems; and 

a graphical user interface controlled by the 
processor, the graphical user including an order entry 
window for receiving order information and routing 
information for an order and a book-view window for 
displaying the order information and execution 
information about an execution for the order, 

the processor electronically transmitting the 
order information to one of the plurality of electronic 
trading systems as determined by the routing information 
and receiving the execution information from the one of 
the plurality of electronic trading systems, 

the graphical user interface displaying the 
order information correlated with the execution 
information on the book- view window. 

57 A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 

the steps of: 

accepting an order at a user workstation, the 

order including order information; 

displaying the order information. on a. screen 
display at the. user workstation; 

electronically transmitting the order to a 
control engine coupled to a plurality of electronic 
trading systems; 
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at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order; 

at the control engine, receiving execution 
information related to the order from the one of the 
plurality of electronic trading systems to which the 

order was routed; 

at the control engine, correlating the 

execution information with the order; 

electronically transmitting the execution 
information from the control engine to the user 

workstation; and 

displaying the execution information on the 
screen display at the user interface correlated with the 
displayed order information. 

58 The method of claim 57 wherein the order is 
accepted from a user operating the user workstation. 

59 The method of claim 57 wherein the order is 
accepted from an expert system coupled to the user 
workstation. 

60 The method of claim 57 wherein the order is 
accepted from an applications program operating on the ■ 
user workstation. 

61. The method of claim 57 wherein the order 
information- includes price information. 

62. The method of claim 57 wherein the order 
• information includes quantity information. 

63. The method of claim 57 wherein the order 
information includes routing information. 
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, rtnim 57 wherein the order 

w o£ data 57 wherein the order ,s a 
The method of c±»*» 

65. 

buy order. , 

,' e laim 57 wherein the order is 
The method of claim 5 

6 o • 

sell order- 

„ f claim 57 wherein the order is 
67> The method of claim 

cover, short order. 

h d of claim 57 wherein the order is 
68 The method of c iaiB 

sell short order. ■'■ •«„ 

' f claim 57 wherein the order is an 

gg The method of claim 

order for a stock. _ 



70; 



the order is an 

^ rt f claim => ' — 

The nv€ 
order for a bond. 

, 57 wherein Che order is an 
The method of claim 57 wh 

order for a future. 

, 4, 57 wherein the order is, an 
72 . The method of claim 57 

order for an option. 



v , of c i a im 57 wherein the 
The method of ciaiu 



order is an 



order for a derivative. 

• c7 wherein the order is an 
The method of claim 57 whe 

order for currency. 

, , m 57 further comprising the 
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• ct further comprising the 

step of sei display screen, 

information from the display 

h Vof claim 57 further comprising the 

- of jsrsr ^ — - 

the display screen. 

of claim 57 further comprising the 

display screen. 

^^^^ 

, • « further comprising the 

information to 

' of claim 57 further comprising the 

. - D£ . - ~- 

profit and loss statement. 

, f claim 57 further comprising. the 
' 82 - ^ me extern information to produce a 

step of utilizing the exec 
purchase and sale report. 

t *od of claim 57 further comprising the 
The method of ^ ^ execution 

step of *^^ unting application program, 
information to an 

, „ try and routing o£ orders to 

method for th. «a«y ^ £or the 

. polity of ^««^ i0 n. of order, , one »etnod 
re al-time reporting of execut 

^^-^rUer at a user workstation, tne 
ord er inoluding order information; 
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eisplay at the user ™~£2x*» «- " ' 

Sle " ^ to a Plurality of electronic 
control engine coupled to 

trading system ele ctroni=ally routing 

-=-vrz.- 

information related to^ the correla cing the 

" Ton vitHh. order in real-t^e: 
execution inlor»tron « <* ng che mention 

ei :;rt,r=»trot «*- » *• -« 

information from the c 

— an -r^^ 
^tr^r ^e/o/der infection. 

. rk6 entry and routing o£ orders to 
K method for the entry ^ 

reporting of «ew 

^ " ePS "accepting an order at a user workstation, the 

oraer including ^"^XTniors.tion on a soreen 
displaying the order a 

display , at the »«^^ ccln3 the order to a ' 
electronically « ^ ^ electronlc 

control engine ooupled to 

trading systems; eieccronically routing 

.ertl^rrprralityo, electronic tredang 

the order to one r; 

systems for execution of th iving execution 

ac the control eng-e. ^ ^ ^ ^ ^ 

information related to the ^ tG which the 

.plurality of electronic trading 

order was routed; S Q002967 
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really transmitting the execution 
information from the co 

workstation; ^rerface, correlating the 

at the user interf^ . ^ .^^.^ and 

execution iaf °^ ti0 \ 1 \xecution information on the 

correlated with the 

screen display.* 

displayed order infor^cron. 

■ ■ „ tr y and routing o£ orders co 

* mechod for r^ ^ry ^ £or the 

reporting of execuu 

8tePS lU.pcing - order at a user station, che 

or der including •*«^ GO « 1 » on a soreen 
displaying Che order ^ ^ 

information is displayed 

display; . tra nsmitting the order to a 

electronically « eleCt ronic 

control engine coupled to a p 

trading systems; eleC tronically routing 

" "I Tele ^ of eleccronic crading 
th . order co on. of Che P 

systems for execution of t» receivin9 sxecucion 

" tM TcfchaTder fro. the one of the 

. in£ or»tion fro. the control engine to c 

workscacion; and „. cuC ion informacion on Che 

displaying Che exeouc ^ 

screen display on Che sal»e ime 

information. 
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- entry and routing of order, to 

* method for the entry ^ fM ^ 

plurality >f electron! tradrng y 
reporting of executions of orders, 

^ ^ eloepting an order at a user workstation, the 
order including order potion at the user 

. ^ ^^U*" designating one of 
workstation, th rou : J 

«e ortet information on a sorssn 

ai splay at the user *• order to a 

eleotronioally tr electronic 
control engine ooupled to a plurality 

crading system, ^ ^ .eotronioall^ ^routing 

tt e order to - ^ -ttlg -struotion for 
trading systems designated by 

execution of the order; reC eiving execution 

at the control engine, recex g ^ 

formation related to ^ted in the 

plurality of electronic trading sy 

routing instruction; _ correlating the 

at the control engine, 

workstation; and „ eC ution information on the 

displaying the correlated with the 

screen display at the user mterf ace 
displayed order information. 

the steps of: workstation, the 

accepting an order at a 
order including order information; 
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. tne order information on a screen 
displaying the order 

display at the -«"*^ t[in9 the order to a 
ele « r0nlC lea cc a plurality of electrons 
control engine coupled co P 

«*« 8yS a :Tne control engine, storing Che order » a 

database; ine , electronically renting 

der - re rrpt^- of electronic trading 

the order to o he ord er; 

^ engine, receiving --ion 

% V. the order from the one o£ the 

information related to the co ^ rte 

plurality of electrons trading 

orde r was rented; ^ C he locution 

ac che ^^"^laced to the order; 
information in the the execution 

'Troche octroi engine to the user 
information from the c 

workstation; and executio n information on the 

_n dis^r/hetse: interface correlated with 

a order information, 
displayed order m 

. entry and routing of orders to 
89 .. . A method 'for the entry ^ ^ ?- 

a pl urality of electron^ Y ^ compris?ing 
reporting of executions of 

^ St6PS Accepting an order at a user workstation, the 

. ord er including ormation on a screen 

displaying tne 

oisplay at the — ^^tting the order to a 
ele otronrcally c ^ electronlc 

oontrol engine coupled to 

ceding systems; ^ ^ ^ cbe order xn a 
database; 
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■«*' electronically routing 

SY a t the con.ro! engine. £rom tbe one 

execution i—^^c ««« " 
o£ che plurality of elect* 

t*e order was storing the execution 



workstation; «.-i-tlaie the execution 

displaying xn real torn ^ worlc8tatlo n 

->,o screen display at 
•information on the sere inf ormation; 

delete. ^ J^t^ accessing «- 

at the user ion ^ornatioa; and 

to Ohtain the «^U tla9 the order and 

electronically « ^ faring system. 

. mention matron to a ccmp 

„ entry and routing o£ orders to 
A method for the » try f tepoECing of 
a source of li^"y.^^ rl 3ing Che steps =f = 

^outions of orders.-* - station, the 

accepting an order a 

order including ^"^^Tnfor^tion on a screen 
displaying the orae 

display at the ^"Z^Z*** «- *~ 

electronically c o£ elec tronl= 

control engine coupled t ^ o£ ^ ^tatross; 
trading systems and a plural y cally routing 

« the control eng-e ^ 
che order." either one of ^ q£ booth . 

trading system or one 
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which the order was 

^« to 

ac Che control engine. correlating the 
at tne ^ or der; 
«ecucicn ^^ansmitting °" eXa "" 0n 

'Trte "°n«ol engine Co the user 
information from the 

workstation; end . ^^iou information on ch 

^Tcle usef incerf ace correlated »rcn 
screen display " hh^ on 

ritsclayed order im« 

„ antry and routing of orders to 
x method for the entry an ^ 

"source of U^ty . -J^ th e steps of = 

— "atcepfC -rder at a user betatron. 

ord er . including option on a screen 

display^ the or« 

display at the -~.r!?£Z*>* «" ° tder ■ 
electronically tran o£ elect: ron:ic 

control engine coupled ^ otn workstations; 

trading systems and a elect r=nically routrng 

at tne control eng- ^ o£ electronic 

* Mder ""Tol eTectron:: execution of « 
«ading of hoorn workstacrons for man 

'execution of tne order; ^ ^ o£ cbe pl urality 

if che order is 
nf bo och worlcscacions, inf ormaCion, 

- tl , oucpuccxng che or ^ ttcal . and 

Ui, accepcxng «ecu " the A 

eieccromcally cr 
execucion inf ormacxon co Che 

engine; receiving execucion 

SST-tU-- trading systems or 
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stations to which the order was 
pW raUty o £ booth »or*statro 

" Uted; at the control engine, correlating the 

^ ti rr: thfo^tro, - - — 

information n . 
„or*station : and ^^ion Information ^on ch e 

„ entry and routing of orders to 
s. method lor the entry » £or che 

- - • 

reporting of execu 

- Opting an order at a user workstation. 

or der coding °^f 0 ^7nformation on a screen 
displaying tne « 
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electronic trading systems, the control engine including 
a database; 

storing the order and the gun code in the 

database; 

at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execution instruction, 
electronically transmitting the gun execute instruction 
to the control engine; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order when the control 
engine receives the gun execute instruction; . 

at the control engine, receiving execution 
information related to the order from the one of the 
plurality of electronic trading systems to which the 
order was routed; 

at the control engine, correlating the 
execution information with the order; 

electronically transmitting the execution 
information from the control engine to the user 
workstation; and 

displaying the execution information on the 
screen display at the user interface correlated with the 
displayed order information. 

105. The method of claim 104 wherein the gun 
execution instruction is received from a user. 

106. The method of claim 104 wherein the gun 
execution instruction is received from an expert system. 

107. The method of claim 104 wherein the gun 
execution instruction is received from an~ application 
program. 
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108. The method of claim 104 wherein the gun 
execution instruction is received from a neural network. 

109 . A method for the entry and routing of orders t 
a plurality of electronic trading .systems, and for the 
reporting of executions of orders, the method comprising 

- the steps of : 

accepting an order at a user workstation 
coupled to an expert system, the order including order 
information; 

at the user workstation, accepting in relation 
to the order a gun code ; 

displaying the order information on a screen 
display at the user workstation; 

electronically transmitting the order and the 
gun code to a control engine coupled to a plurality of 
electronic trading systems, the control engine including 
a database; 

storing the order and the gun code in the 

database; 

at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execution instruction, 
electronically transmitting the gun execute instruction, 
to the control engine; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order when the control 
engine receives the gun execute instruction; 

at the control engine, receiving execution 
information related to the order from the one of the 
plurality of electronic trading systems to which the 
order was routed; 

at the control engine, correlating the 
execution information with the order; 
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electronically transmitting the execution 
information from the control engine to the user 
workstation; and 

at the user workstation, electronically 
transmitting the execution information to the expert 
system. 

110. The method of claim 109 wherein the gun 
execution instruction is received from a user. 

111. The method of claim 109 wherein the gun 
execution instruction is received from the expert system. 

112. The method of claim 109 wherein the gun 
execution instruction is received from the expert system 
in response to execution information. 

113. A method for the entry and routing of orders to 
a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders at a user 
workstation, each one of the plurality of orders 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation ; 

at the user workstation, accepting a gun code 
relating to the plurality of orders; 

at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execution instruction 
and in response thereto, electronically and immediately 
transmitting the plurality of orders to a control engine 
coupled to a plurality of electronic trading systems; 
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at the control engine, electronically routing 
each one of the plurality of orders to the plurality of 
electronic trading systems for execution; 

at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control engine; 

electronically transmitting the plurality of 
execution reports from the control engine to the user 
workstation as each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports 
on the screen display at the user interface correlated 
with the displayed order information. 

114. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders at a user 
workstation, each one of the plurality of orders 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation; 

at the us^r workstation, accepting. a gun code 
relating to the plurality of orders; 

electronically, transmitting the plurality of 
orders to a control engine including a database and 
coupled to a plurality of electronic trading systems; 

a!t the control engine, storing the plurality of 
orders and the gun code in the database,; 
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at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execution, 
electronically transmitting the gun execution instruction 
to the control engine; 

at the control engine, electronically routing 
each one of the plurality of orders to the plurality of 
electronic trading systems for execution when the gun 
execute instruction is received at the control engine; 

at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems ; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control engine; 

electronically transmitting the plurality of 
execution reports from the control engine to the user 
workstation as each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports 
on the screen display at the user interface correlated 
with the displayed order information. 

115. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders a£ a user 
workstation, each one of the plurality of orders 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation; 
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at the user workstation, accepting a gun code 
relating to the plurality of orders; 

storing the plurality of orders and the gun 

code;. 

at the user workstation, accepting a dollar 

limit; 

at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execute instruction and 
responsive thereto, electronically transmitting a portion 
of the plurality of orders to a control engine coupled to 
a plurality of electronic trading systems such that if 
the portion of orders are executed, the value of the 
execution will be the dollar amount ; 

at the control engine, electronically routing 
the portion of the plurality of orders to the plurality 
of electronic trading systems for execution; 

at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems ; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control .engine ; 

electronically , transmitting the plurality of 
execution reports from the control engine to the user 
workstation as each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports ' X 
on the screen display at the user interface correlated 
with the displayed order information. 

116. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
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reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders at a user 
workstation, each one of the plurality of orders 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation; 

at the user workstation, accepting a gun code 
relating to the plurality of orders; 

electronically transmitting the plurality of 
orders to a control engine and coupled to a plurality of 
electronic trading systems ; 

storing the plurality of orders and the gun 



at the user workstation, accepting a dollar 



code ; 
limit; 

at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

electronically transmitting the gun execution 
instruction and the dollar limit to the control engine ; 

at the control engine, electronically routing a 
portion of the plurality of orders to the plurality of 
electronic trading systems for execution when the gun 
execute instruction is received at the control engine 
such that if the portion of orders are executed, the 
value of the execution will be the dollar amount; 

at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control engine; 
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electronically transmitting the plurality of 
execution reports from the control engine to the user 
workstation as each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports 
on the screen display at the user interface correlated 
with the displayed order information. 

117. A method. for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders at a user 
workstation, each one of the plurality of orders 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation; 

at the user workstation, accepting a gun code 
relating to the plurality of orders; 

storing the plurality of orders and the gun 

code ; 
limit; 



at the user workstation, accepting a percentage 



at the user workstation, accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

upon receipt of the gun execution instruction 
and responsive thereto, electronically transmitting a 
portion of the plurality of orders to a control engine 
coupled to a plurality of electronic trading systems such 
that the percentage of the plurality of orders 
transmitted equals, the percentage limit; 

at the control engine, electronically 
transmitting the portion of the plurality of orders, to 
the plurality of electronic trading systems for 
execution; 
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at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control engine; 

electronically transmitting the plurality of 
execution reports from the control engine to the user 
workstation as -each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports 
on the screen display at the user interface correlated 
with the displayed order information. 

118. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting a plurality of orders at a user 
workstation, each one of the plurality of orders - 
including order information; 

displaying the order information for each of 
the plurality of orders on a screen display at the user 
workstation; 

at the user workstation, accepting a gun code 
relating to the plurality of orders; 

electronically transmitting the plurality of 
orders to a control engine including a database and 
coupled to a plurality of electronic trading - systems ; 

at the control engine, storing the plurality of 
orders and the gun code in the database; 

at the user workstation, accepting a percentage 

limit; 
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at the user workstation,- accepting a gun 
execute instruction, the gun execute instruction 
identifying the gun code; 

electronically transmitting the gun execution 
instruction and the percentage limit to the control 
engine ; 

at the control engine, electronically routing a 
percentage of the plurality of orders to the plurality of 
electronic trading systems for execution when the gun 
execute instruction is received at the control engine 
such that the percentage of the plurality of orders sent 
for execution equals the percentage limit; 

at the control engine, receiving from the 
plurality of electronic trading systems a plurality of 
execution reports, each one of the plurality of execution 
reports related to one of the plurality of orders from 
the plurality of electronic trading systems; 

at the control engine, correlating each one of 
the plurality of execution reports with each one of the 
plurality of orders as each one of the plurality of 
execution reports is received by the control engine; 

electronically transmitting the plurality of 
execution reports from the control engine to the user 
workstation as each one of the plurality of execution 
reports is received by the control engine; and 

displaying the plurality of execution reports 
on the screen display at the user interface correlated 
with the displayed order information. 

119. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting an order at a user workstation, the 
order including order information ; 

if required by a user, displaying the order 
information on a screen display at the user workstation; 

S0002990 
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electronically transmitting the order to a 
control engine coupled to a plurality of electronic 
trading systems; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order; 

at the control engine, receiving execution 
information related to the order from the one of the 
plurality of electronic trading systems to which the 
order was routed; 

at the control engine, correlating the 
execution information with the order; 

electronically transmitting the execution 
information from the control engine to the user 
workstation; and 

if required by the user, displaying the 
execution information on the screen display at. the user 
interface correlated with the displayed order 
information. 

120, A method for the fast entry of orders by a user 

at a user workstation including a graphical user 
interface and for the routing of the orders to a 
plurality of electronic trading systems, the method 
comprising the steps of : 

at a user workstation, displaying on the 
graphical user interface a plurality of order type 
buttons, a plurality of symbol buttons, a plurality of 
routing buttons and an enter order button; ' 

receiving an order type instruction from the 
user when the user selects one of the plurality of order 
type buttons; * N 

receiving a symbol instruction from the user 
when the user selects one of the plurality of symbol 
buttons ; 
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receiving a routing instruction from the user 
when the user selects one of the plurality of routing 
buttons ; 

displaying a pre- selected order quantity on the 
graphical user interface; 

displaying a pre- selected order price on the 
graphical user interface; 

electronically transmitting the order type 
instruction, the symbol instruction, the routing 
instruction, the order quantity and the order price to a 
control engine coupled to a plurality of electronic 
trading systems when the user selects the enter order 
button; and 

at the control engine, electronically routing 
an order for execution to one of the plurality of 
electronic trading systems specified by the routing 
instruction, the order including an order type as 
specified by the order type instruction, an instrument as 
specified by the symbol instruction, the order quantity 
and the order price. 

121. a method for the fast entry of orders by a user 

at a user workstation including a graphical user 
interface and for the routing of the orders to a 
plurality of electronic trading systems, the method 
comprising the steps of: 

at a user workstation, displaying on the 
graphical user interface a plurality of order type 
buttons, a plurality of symbol buttons, a plurality of 
routing buttons and an enter order button; 

receiving an order type instruction from the 
user when the user selects one of the plurality of order 
type buttons; 

receiving a symbol instruction from the user 
when the user selects one of the plurality of symbol 
buttons; 
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receiving a routing instruction from the user 
when the user selects one of the plurality of routing 
buttons; 

obtaining an order quantity from a database; 
displaying the order quantity on the graphical 
user interface; 

obtaining an order price from the database; 
displaying the order price on the graphical 
user interface; 

electronically transmitting the order type 
instruction, the symbol instruction, the routing 
instruction, the order quantity and the order price to a 
control engine coupled to a plurality of electronic 
trading systems when the user selects the enter order 
button; and 

at the control engine, electronically routing 
an order for execution to one of the plurality of 
electronic trading Bystems specified by the routing 
instruction, the order including an order type as 
specified by the order type instruction, an instrument as 
specified by the symbol instruction, the order quantity 
and the order price. 

122. A method for the fast entry of orders by a user 

at a user workstation including a graphical user 
interface and for the routing of the orders for 
execution, the method comprising the steps of: 

at a user workstation, displaying on the 
graphical user interface a plurality of order type 
buttons, a plurality of symbol buttons, a plurality of 
routing buttons and an enter order button; 

receiving an order type instruction from the 
user when the user selects one of the plurality of order 
type buttons; 

receiving a symbol instruction from the user 
when the user .selects one of - the plurality of symbol 
buttons; 
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receiving a routing instruction from the user 
when the user selects one of the plurality of routing 
buttons; 

• displaying a pre-selected order, quantity on the 
graphical user interface; 

displaying an order price related to the 
current market price on the graphical user interface; and 

electronically transmitting the order type 
instruction, the symbol instruction, the routing 
instruction, the. order quantity and the order price to a 
control engine for routing by the control engine when the 
user selects the enter order button. 

123. A method for the fast entry of orders by a user 

at a user workstation including a graphical user 
interface and for the routing of the orders for 
execution, the method comprising the steps of: 

at a user workstation, displaying on the 
graphical user interface a plurality of order type 
buttons, a plurality of symbol buttons, a plurality of 
routing buttons and an enter order button; 

receiving an order type instruction from the 
user when the user selects one of the plurality of order 
type buttons; 

receiving a symbol instruction from the user . 
when the user selects one of the plurality of symbol , 
buttons; 

receiving a routing instruction from the user 
when the user selects one of the plurality of routing 
buttons; 

displaying a pre-selected order quantity on the 
graphical user interface; 

allowing the user to modify the pre-selected 
order quantity at the graphical user interface; 

allowing the user to enter an order price at 
the graphical user interface; and 
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electronically transmitting the order type 
instruction, the symbol instruction, the routing 
instruction, the order quantity and the order price to a 
control engine coupled to a plurality of electronic 
trading systems when the user. selects the enter order 
button. 

124. A method for the fast entry of orders by a user 
at a user workstation including a graphical user 
interface and for the routing of the orders for 
execution, the method comprising the steps of: 

at a user workstation, displaying on the 
graphical user interface a plurality of order type 
buttons, a plurality of symbol buttons, a plurality of 
routing buttons and an enter order button; 

receiving an order type instruction from the 
user when the user selects one of the plurality of order 
type buttons; 

receiving a symbol instruction from the user 
when the user selects one of the plurality of symbol 
buttons; 

receiving a routing instruction from the user 
when the user selects one of the plurality of routing 
buttons; 

allowing the user enter an order quantity at 
the graphical user interface; 

allowing the user to enter an order price at 
the graphical user interface; and 

electronically transmitting the order type 
instruction, the symbol instruction, the routing 
instruction, the order quantity and the order price to a 
control engine coupled to a plurality of electronic 
trading systems when the user selects the enter order 
button. 

125. a method for the entry and routing of orders to 
a plurality of electronic trading systems, and for the 
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reporting of executions of orders, the method comprising 
the steps of : 

accepting an order at a user workstation, the 
order including order information; 

displaying the order information on a screen 
display at the user workstation; 

electronically transmitting the order to a 
control engine coupled to a plurality of electronic 
trading systems for routing by the control engine to one 
of the plurality of electronic trading systems ; 

receiving, in real-time, electronically 
transmitted execution information relating to the order 
from the control engine; and 

displaying, in real-time, the execution 
information on the screen display at the user interface 
correlated with the displayed order information. 

126. A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

receiving on-line market information at a user 
workstation from an on-line source of market information; 

accepting instrument information identifying a 
instrument at the user workstation, the user workstation 
including a graphical user interface; 

displaying market information about the 
instrument on the graphical user interface of the user 
workstation; 

accepting an order at a user workstation 
related to the instrument, the order including order 
information; ^ x 

displaying the order information on a screen 
display at the user workstation; 

accepting a boolean condition at the user 
workstation; 
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examining the on-line market information to 
determine if the boolean condition is true; 

electronically transmitting the order to a 
control engine coupled to a plurality of electronic 
trading systems when the boolean condition becomes true; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order; 

at the control engine, receiving execution 
information related to the order from the one of the 
plurality of electronic trading systems to which the 
order was routed; 

at the control engine, correlating the 
execution information with the order; 

electronically transmitting the execution 
information from the control engine to the user 
workstation; and 

displaying the execution information on the 
screen display at the user interface correlated with the 
displayed order information. 

I 27 - A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting an order at a user workstation, the 
order including order information; 

displaying the order information on a screen 
display at the user workstation; 

electronically transmitting the order to a 
control engine . coupled to a plurality of electronic 
trading systems, the control engine including an 
electronic database; 

at the control engine, storing the order ..in the 

database ; 
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at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order; 

at the. user workstation, receiving a command to 
suspend the order; 

at the user workstation, displaying a suspend 
indicator with the displayed order information on the 
screen display; 

electronically transmitting a cancel order to 
the control engine to cancel the execution of the order; 

at the control engine, electronically routing 
the cancel order to the one of the plurality of 
electronic trading systems; and 

modifying the stored order in the database to 
indicate that the order has been suspended. 

12 8 • A method for the entry and routing of orders to 

a plurality of electronic trading systems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting an order at a user workstation, the 
order including order information; 

displaying the order information on a screen 
display at the user workstation; 

electronically transmitting the order to a 
control engine coupled to a plurality of electronic . 
trading systems, the control engine including an 
electronic database; 

at the control engine, storing the order in the 

database; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution, of the order; 

at the user workstation, receiving a suspend 
command to suspend the order; 
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at the user workstation, displaying a suspend 
indicator with the displayed order information on the 
screen display; 

electronically transmitting a cancel order to 
the control engine to cancel the execution of the order; 

. at the control engine, electronically routing 
the cancel order to the one of the plurality of 
electronic trading systems; 

modifying the stored order in the database to 
indicate that the order has been suspended; 

at the user workstation, receiving a release 
command to release the suspended order; 

at the user workstation, replacing the display 
of the suspend indicator with a release indicator on the 
screen display; 

electronically transmitting a release order to 
the control engine to execution of the order; 

at the control engine, retrieving the order 
from the database; and 

at the control engine, electronically routing 
the order to the one of the plurality of electronic 
trading systems for re-entry of the order. 

129 . A method for the entry and routing of orders to 

a plurality of electronic trading Bystems, and for the 
reporting of executions of orders, the method comprising 
the steps of: 

accepting an order at a user workstation, the 
order including order information; 

electronically transmitting the order to a 
control engine coupled to a plurality of electronic 
trading systems; 

at the control engine, electronically routing 
the order to one of the plurality of electronic trading 
systems for execution of the order; 

at the control engine, receiving execution 
information related to the order from the one of the 
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plurality of electronic trading systems to which the 
order was routed ; 

at the control engine/ correlating the 
execution information with the order; 

electronically transmitting the execution 
information from the control engine to the user 
workstation; 

displaying the order information on a screen 
display at the user workstation; and 

displaying the execution information on the 
screen display at the user interface correlated with the 
displayed order information. 
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